搬砖:
蛇形矩阵 找规律题 最佳解法
1 3 6 10
2 5 9
4 8
7
第一行[1 3 6 10]
第二行是 去掉第一行的第一列,然后将后面的[3 6 10]分别减1得到的
解法:
(1)求第一行第n项规律。
n*(n+1)/2
给出的各项可看出
a(n+1)-a(n)=n+1,于是
a(n)-a(n-1)=n
……
a(2)-a(1)=2
以上各项相加得
a(n+1)-a(1)=(n+1)+n+……+2
所以a(n+1)=(n+1)+n+……+2+1
则a(n)=n+……+2+1=n*(n+1)/2
(2)第二行是 去掉第一行的第一列,然后将后面的[3 6 10]分别减1得到的
while True:
try:
N=int(input())
res=[]
for i in range(N):
if i==0:
res=[(e+2)*(e+1)//2 for e in range(N)]
else:
res=[e-1 for e in res[1:]]
print(' '.join(map(str,res)))
except:
break
京公网安备 11010502036488号