题解 | #蛇形矩阵#

蛇形矩阵

http://www.nowcoder.com/practice/649b210ef44446e3b1cd1be6fa4cab5e

while 1:
    try:
        '''
        #方法一:纯数学计算 方方正正的 按照矩阵的每一行每一列来算
        for i in range(n):
            for j in range(n-i):
                m[i][j]=(1+i*(1+i)/2)+(1+i*(1+i)/2)
        #方法二:方法一的一半,数学计算+形式上的规律,只需要算第一行,然后从这一行的第二个数开始减一即可得到下一行

        #方法三:斜着!的数学计算!!!
        m[i][j]=[(1+(i))*i/2+1] + (n-i) #错了 

        '''
        num = int(input())
        m = [[0 for i in range(num - i)] for i in range(num)]
        for i in range(num):
            if i == 0:
                m[i] = [(x + 2) * (x + 1) // 2 for x in range(num)]
            else:
                m[i] = [x - 1 for x in m[i - 1][1:]]
        for i in range(len(m)):
            print(' '.join([str(j) for j in m[i]]))      
            #这里有坑:当list中含有int数的时候,不可以直接用join方法把它转换为字符串,需要先把list中的每个字符搞成字符串 再用字符串标识符''联接join
    except:
        break
全部评论

相关推荐

11-28 17:58
门头沟学院 Java
美团 JAVA开发 n×15.5
牛客786276759号:百度现在晋升很难的 而且云这块的业务没美团好 你看百度股价都跌成啥样了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务