小编man*_*dka的帖子

python 3:列表的值在进入for循环时发生变化

挑战:找到可从包含5个元素的列表中的四个元素中获得的最小和最大总和.

接下来的方法:按降序和升序对列表进行排序,并将它们存储到两个不同的变量中.找到两个列表中前4个元素的总和.一个总和是最小的,第二个是最大的.

代码:

arr = [2,1,3,4,5]
arr.sort()
asc = arr
print(asc[0],asc[1],asc[2],asc[3])
arr.sort(reverse = True)
des = arr
print(des[0],des[1],des[2],des[3])
maxi = 0
mini = 0
for j in range(4) :
    mini = mini + asc[j]
    print(mini, asc[j])
    maxi = maxi + des[j]
    print(maxi,des[j])
print(mini, maxi)
Run Code Online (Sandbox Code Playgroud)

这里引入的打印语句很少用于调试目的.在代码中可见,bot在进入for循环之前和进入循环之后打印已排序的版本.如输出中所见,它清晰可见,应该按升序保持元素的列表具有降序的元素.

输出:

11 12 13 14 - list in the ascending order
15 14 13 12 - list in the descending order

15 15 - round 0
15 15

29 14 - round 1
29 14 …
Run Code Online (Sandbox Code Playgroud)

python arrays sorting

2
推荐指数
1
解决办法
70
查看次数

标签 统计

arrays ×1

python ×1

sorting ×1