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