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