鱼C论坛

 找回密码
 立即注册
查看: 1726|回复: 2

[已解决]python最新版23讲动手题2,幸运数字

[复制链接]
发表于 2022-7-20 13:18:55 | 显示全部楼层 |阅读模式

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

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

x
答案代码如下:
matrix = [[10, 36, 52],
          [33, 24, 88],
          [66, 76, 99]]
   
row = len(matrix)
col = len(matrix[0])
   
min_row = [1024] * row
max_col = [0] * col
   
# 遍历矩阵中的每一个元素
# 找到每行中最小的元素,并将它们存放到列表min_row中
# 找到每列中最大的元素,并将它们存放到列表max_col中
for i in range(row):
    for j in range(col):
        min_row[i] = min(matrix[i][j], min_row[i])
        max_col[j] = max(matrix[i][j], max_col[j])
   
# 遍历矩阵中的每一个元素
# 判断是否同时满足“同一行的所有元素中最小”和“同一列的所有元素中最大”
for i in range(row):
    for j in range(col):
        if matrix[i][j] == min_row[i] and matrix[i][j] == max_col[j]:
            print(matrix[i][j])



不理解:
min_row = [1024] * row
max_col = [0] * col


min_row[i] = min(matrix[i][j], min_row[i])
max_col[j] = max(matrix[i][j], max_col[j])
最佳答案
2022-7-20 13:18:56
因为后期要将min_row与max_col里的元素与原列表里的元素进行大小比较。所以要保证min_row里的值足够大,max_col足够小。



min_row[i] = min(matrix[i][j], min_row[i])
max_col[j] = max(matrix[i][j], max_col[j])

这两句,就是把原列表遍历,min_row负责将每个元素与自身元素比较,返回每行的最小数,因为它的下标是i,i表示行

min_col同理

欢迎追问~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-7-20 13:18:56 | 显示全部楼层    本楼为最佳答案   
因为后期要将min_row与max_col里的元素与原列表里的元素进行大小比较。所以要保证min_row里的值足够大,max_col足够小。



min_row[i] = min(matrix[i][j], min_row[i])
max_col[j] = max(matrix[i][j], max_col[j])

这两句,就是把原列表遍历,min_row负责将每个元素与自身元素比较,返回每行的最小数,因为它的下标是i,i表示行

min_col同理

欢迎追问~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-7-20 18:12:06 | 显示全部楼层
青出于蓝 发表于 2022-7-20 13:18
因为后期要将min_row与max_col里的元素与原列表里的元素进行大小比较。所以要保证min_row里的值足够大,max ...

谢谢谢懂啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-28 14:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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