题解 | #蛇形矩阵#

蛇形矩阵

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
全部评论

相关推荐

05-26 22:25
门头沟学院 Java
Java小肖:不会是想叫你过去把你打一顿吧,哈哈哈
点赞 评论 收藏
分享
小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务