tercel


私信TA

用户名:773166228

访问量:723

签 名:

等  级
排  名 3044
经  验 1993
参赛次数 2
文章发表 3
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:

先输入他的n*n的矩阵,所有可以直接for加一个空的列表来组成一个二维列表。

从左上角到右下角的对角线比较好做一些直接嵌套一个for循环然后判断一下这个二维数组的下标是否相等。
注意事项:

重点在于第三个很多人都有错误,不能光看那个样例,他可能会有偶数和奇数的所以要判断一下,偶数的话直接一次一次加就行了,奇数才是出错的那个地方因为偶数的话对角线没有重叠的地方,而奇数有所以要减掉一便对角线重复的那个数。

还有一个就是输入一个数的时候要单独加个判断。
参考代码:

n = int(input())
lis = []
for i in range(n):
   a = list(map(int,input().split()))
   lis.append(a)
sum = 0
for i in range(len(lis)):
   for j in range(len(lis[i])):
       if i == j:
           sum += lis[i][j]
sun = 0
s = 0
if n % 2 != 0:
   s1 = (int(pow(n,0.5)))
   for i in range(n-1,-1,-1):
       if s != s1:
           sun += lis[i][s]
       s += 1
else:
   for i in range(n-1,-1,-1):
       sun += lis[i][s]
       s += 1
if n == 1:
   print(lis[0][0])
else:
   print(sum+sun)

 

0.0分

4 人评分

  评论区