鱼C论坛

 找回密码
 立即注册
查看: 480|回复: 1

[已解决]判断给定的方阵是否上三角矩阵。

[复制链接]
发表于 2023-12-25 19:35:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述:
判断给定的方阵是否上三角矩阵。

输入:
输入第一行给出一个正整数T,为待测矩阵的个数。接下来给出T个矩阵的信息:每个矩阵信息的第一行给出一个不超过10的正整数n。随后n行,每行给出n个整数,其间以空格分隔。

输出:
每个矩阵的判断结果占一行。如果输入的矩阵是上三角矩阵,输出“YES”,否则输出“NO”

输入样例:
2
3
1 2 3
0 4 5
0 0 6
2
1 0
-8 2
输出样例:
YES
NO

这题怎么做
最佳答案
2023-12-25 19:35:54
可以通过遍历矩阵的下三角元素,判断是否有非零元素存在来判断矩阵是否为上三角矩阵。

具体实现代码如下:
  1. def is_upper_triangular(matrix):
  2.     n = len(matrix)
  3.     for i in range(n):
  4.         for j in range(i+1, n):
  5.             if matrix[j][i] != 0:
  6.                 return False
  7.     return True
  8. T = int(input("请输入待测矩阵的个数:"))
  9. for _ in range(T):
  10.     n = int(input("请输入矩阵的大小:"))
  11.     matrix = []
  12.     for _ in range(n):
  13.         row = list(map(int, input().split()))
  14.         matrix.append(row)
  15.    
  16.     if is_upper_triangular(matrix):
  17.         print("YES")
  18.     else:
  19.         print("NO")
复制代码

这样就可以输入矩阵的大小和元素,然后判断是否为上三角矩阵并输出结果了。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-12-25 19:35:54 | 显示全部楼层    本楼为最佳答案   
可以通过遍历矩阵的下三角元素,判断是否有非零元素存在来判断矩阵是否为上三角矩阵。

具体实现代码如下:
  1. def is_upper_triangular(matrix):
  2.     n = len(matrix)
  3.     for i in range(n):
  4.         for j in range(i+1, n):
  5.             if matrix[j][i] != 0:
  6.                 return False
  7.     return True
  8. T = int(input("请输入待测矩阵的个数:"))
  9. for _ in range(T):
  10.     n = int(input("请输入矩阵的大小:"))
  11.     matrix = []
  12.     for _ in range(n):
  13.         row = list(map(int, input().split()))
  14.         matrix.append(row)
  15.    
  16.     if is_upper_triangular(matrix):
  17.         print("YES")
  18.     else:
  19.         print("NO")
复制代码

这样就可以输入矩阵的大小和元素,然后判断是否为上三角矩阵并输出结果了。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 12:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表