码迷,mamicode.com
首页 > 编程语言 > 详细

Python 中使用 for、while 循环打印杨辉三角练习(列表索引练习)。

时间:2017-09-25 11:31:16      阅读:301      评论:0      收藏:0      [点我收藏+]

标签:for while 列表索引 杨辉三角

Python中使用for while循环打印杨辉三角练习(列表索引练习)。

杨辉三角是一个由数字排列成的三角形数表,一般形式如下: 

1 1 

1 2 1 

1 3 3 1 

1 4 6 4 1 

1 5 10 10 5 1 

1 6 15 20 15 6 1 

.......................

杨辉三角最本质的特征是,它的两条斜边都是由数字1组成的,而其余的数则是等于它肩上的两个数之和。


方法一:


    __author__ = ‘Brad‘

    n = int(input(‘请输入你想打印杨辉三角的行数:‘)

    newline = [1]   

    oldline = []    

    print(newline)  

    

    for i in range(1,n):    

        oldline = new.copy()    

        oldline.append(0)

        newline.clear()

        for j in range(i+1):

            newline.append(oldline[j-1]+oldline[j])

        print(newline)

        

        





杨辉三角的特征:第n行有n个元素,从第三行起,newline[1]=oldline[0]+oldine[1]……杨辉三角可以在右侧扩展出一列全部为0,这样从第二行开始,newline[0]=oldline[-1]+oldline[0],并且newline[0]也可由oldline的元素计算得出。


     1 0

     1 1 0

     1 2 1 0

     1 3 3 1 0

     1 4 6 4 1 0

     1 5 10 10 5 1 0

     1 6 15 20 15 6 1 0

     

#第一行的列表需要直接打印

#这个newline是经过计算

#通过对这个oldline的元素进行计算得出newline中的元素

#剩余n-1行,通过循环n-1次分别打印经计算出的newline,所以区间设为(1,n)

开始计算第二行,将第一行copy给oldline,用于计算。

oldline列表添加一个0,成为我们想要的杨辉三角变形。

做一个空行newline,里面的元素通过计算得出

oldline[0]+oldline[1],oldline[0]+oldline[1]索引顺序重复不好处理,可以尝试使用负索引oldline[-1]+oldline[0],oldline[0]+oldline[1]正好得出第二行的元素:[1,1],这时尝试将j的区间设为[0,1]即[i+1]

后面逐行也都符合要求。

结果为:


    :6

    [1]

    [1, 1]

    [1, 2, 1]

    [1, 3, 3, 1]

    [1, 4, 6, 4, 1]

    [1, 5, 10, 10, 5, 1]


方法二:


杨辉三角从第三行开始,triangle[1]到triangle[n-1]都可以由上一行的元素计算得出。




    __author__ = ‘Brad‘

    n = int(input(‘请输入你想打印杨辉三角的行数:‘)

    triangle=[[1],[1,1]]

    

    for i in range(2,n):

        pre=triangle[i-1]

        cur=[1]

        for j in range(i-1):

            cur.append(pre[j]+pre[j+1])

        cur.append(1)

        triangle.append(cur)

    print(triangle)


triangle[0]和triangle[n-1]不计算,分别在第一个循环首尾定义和增加,只计算剩余的元素,将每一行的元素添加为triangle的元素,作为下一行cur计算的pre。

前两行不方便计算,直接列出。从第三行开始计算,i = 2 pre=tirangle[1],cur[1]=1+1即pre[0]+pre[1],所以将j的区间设置为(i-1),接下来计算顺利,直接打印即为杨辉三角。

结果为:


    :6

    [[1], [1, 1], [1, 2, 1], [1, 3, 3, 1], [1, 4, 6, 4, 1], [1, 5, 10, 10, 5, 1]]


方法三:


        __author__ = ‘Brad‘

    n = int(input(‘请输入你想打印杨辉三角的行数:‘)

    triangle=[]

    

    for i in range(n):

        row=[1]

        triangle.append(row)

        if i==0:

            continue

        for j in range(i-1):

            row.append(triangle[i-1][j]+triangle[i-1][j+1])

        row.append(1)

    print(triangle)

    

在这个方法中row相当于方法二中的cur,每次计算初始都是[1].


当i==0时,triangle再添加[1]变为[[1],[1]],


当i==2时,row[1]增加triangle[1][0]+triangle[1][0],然后再增加[1],变为[[1],[2],[1]。

然后依次打印。结果为:


    :6

    [[1], [1, 1], [1, 2, 1], [1, 3, 3, 1], [1, 4, 6, 4, 1], [1, 5, 10, 10, 5, 1]]


Python 中使用 for、while 循环打印杨辉三角练习(列表索引练习)。

标签:for while 列表索引 杨辉三角

原文地址:http://13320196.blog.51cto.com/13310196/1968250

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!