小儿无赖 发表于 2023-8-1 22:02:24

求大神纠错,改了一个晚上了,也问了一些鱼油们,但最后还是有点问题,感激不尽

"""随机整数矩阵找幸运数"""

import random

m = int(input("请输入矩阵的行数:"))
n = int(input("请输入矩阵的列数:"))

matrix = [ for i in range(m)]

#matrix也可以这样写:
#matrix = []
#for i in range(m):
#   matrix.append(random.choices(range(2025), k=n))

for i in range(m):
    for j in range(n):
      if all(matrix <= matrix for k in range(n)) and all(matrix >= matrix for l in range(m)):
            print("这个随机矩阵的幸运数如下:")
            print(matrix)
      else:
            continue
      break
print("很不幸,这个随机矩阵没有幸运数")

Mike_python小 发表于 2023-8-1 22:02:40

以下是改正后的代码:


import random

m = int(input("请输入矩阵的行数:"))
n = int(input("请输入矩阵的列数:"))

matrix = [ for i in range(m)]

lucky_numbers = []

for i in range(m):
    for j in range(n):
      if all(matrix <= matrix for k in range(n)) and all(matrix >= matrix for l in range(m)):
            lucky_numbers.append(matrix)

if lucky_numbers:
    print("这个随机矩阵的幸运数如下:")
    for num in lucky_numbers:
      print(num)
else:
    print("很不幸,这个随机矩阵没有幸运数")


在改正后的代码中,主要做了以下几点修改:
1. 修正了代码中的缩进问题,确保代码块的正确嵌套。
2. 添加了一个列表lucky_numbers来存储幸运数。
3. 在找到幸运数时,将其添加到lucky_numbers列表中。
4. 最后根据lucky_numbers列表是否为空来判断是否有幸运数,并进行相应输出。

希望这样的改动能够解决你在代码中遇到的问题。如果还有其他疑问,请随时提问。

isdkz 发表于 2023-8-1 22:02:43

这段代码的目标是从一个随机整数矩阵中找出幸运数。幸运数的定义是在其所在的行和列中都是最小值。

代码中存在一些问题,我将帮您做出改正和解释。

import random

m = int(input("请输入矩阵的行数:"))
n = int(input("请输入矩阵的列数:"))

matrix = [ for i in range(m)]

#matrix也可以这样写:
#matrix = []
#for i in range(m):
#    matrix.append(random.choices(range(2025), k=n))

lucky_numbers = []# 用于存储幸运数的列表

for i in range(m):
    for j in range(n):
      # 检查是否是行中最小值,并且是否是列中最小值
      if all(matrix[ i] <= matrix[ i] for k in range(n)) and all(matrix[ i] <= matrix for l in range(m)):
            lucky_numbers.append(matrix[ i])

if lucky_numbers:
    print("这个随机矩阵的幸运数如下:")
    print(lucky_numbers)
else:
    print("很不幸,这个随机矩阵没有幸运数")


改正和解释:
1. 在原始代码中,如果发现第一个元素不是幸运数,则会直接进入下一行的循环,而忽略了其他可能的幸运数。现在,我已经修复了这个问题,使用 lucky_numbers 列表来存储所有的幸运数,并在最后进行输出。
2. 添加了注释来帮助理解代码的逻辑和功能。

现在,该代码应该能够正确地从随机整数矩阵中找出幸运数,并输出结果。如果您还有其他问题或疑惑,请随时问我。

学习编程中的Ben 发表于 2023-8-1 22:03:36

以下是改正后的代码:


import random

m = int(input("请输入矩阵的行数:"))
n = int(input("请输入矩阵的列数:"))

matrix = [ for i in range(m)]

lucky_numbers = []

for i in range(m):
    for j in range(n):
      if all(matrix <= matrix for k in range(n)) and all(matrix >= matrix for l in range(m)):
            lucky_numbers.append(matrix)

if lucky_numbers:
    print("这个随机矩阵的幸运数如下:")
    for num in lucky_numbers:
      print(num)
else:
    print("很不幸,这个随机矩阵没有幸运数")


在改正后的代码中,主要做了以下几点修改:
1. 修正了代码中的缩进问题,确保代码块的正确嵌套。
2. 添加了一个列表lucky_numbers来存储幸运数。
3. 在找到幸运数时,将其添加到lucky_numbers列表中。
4. 最后根据lucky_numbers列表是否为空来判断是否有幸运数,并进行相应输出。

希望这样的改动能够解决你在代码中遇到的问题。如果还有其他疑问,请随时提问。

如果回答对你有帮助,请给我一个最佳答案!{:10_254:}{:10_254:}{:10_254:}

小儿无赖 发表于 2023-8-1 22:08:47

Mike_python小 发表于 2023-8-1 22:02
以下是改正后的代码:



感谢

小儿无赖 发表于 2023-8-1 22:09:25

学习编程中的Ben 发表于 2023-8-1 22:03
以下是改正后的代码:




感谢

sfqxx 发表于 2023-8-1 22:10:48

"""随机整数矩阵找幸运数"""

import random

m = int(input("请输入矩阵的行数:"))
n = int(input("请输入矩阵的列数:"))

matrix = [ for i in range(m)]

#matrix也可以这样写:
#matrix = []
#for i in range(m):
#   matrix.append(random.choices(range(2025), k=n))

for i in range(m):
    for j in range(n):
      if all(matrix <= matrix for k in range(n)) and all(matrix >= matrix for l in range(m)):
            print("这个随机矩阵的幸运数如下:")
            print(matrix)
      else:
            continue
      break
print("很不幸,这个随机矩阵没有幸运数")

小儿无赖 发表于 2023-8-1 22:12:13

isdkz 发表于 2023-8-1 22:02
这段代码的目标是从一个随机整数矩阵中找出幸运数。幸运数的定义是在其所在的行和列中都是最小值。

代码 ...

感谢
页: [1]
查看完整版本: 求大神纠错,改了一个晚上了,也问了一些鱼油们,但最后还是有点问题,感激不尽