import random
A=[]
for i in range(10):
A.append(random.randint(0,100))
print(A)
x=A
for i,j in enumerate(x):#从这往下就看不懂了
T=x[i+1:]
if T==[]:
break
if x[i]>min(T):
t=x.index(min(T))
x[i],x[t]=x[t],x[i]
print(A)
python 随机生成10个数并升序排序 升序排序的那部分代码不太明白 想知道是怎么实现的
谢谢大家!
【若能有所悟,望给个采纳,谢谢】
1、enumerate:这个是与for循环配合实用,用于遍历数据对象(列表、元组或字符串均可)
2、for i,j enumerate(x)
这里的i=指的是数组的下标值,j=指的是下标值对应的值
3、T=x[i+1:]
意思就是从数组下标i+1开始,取出所有数组值
1)比如:[1,2,3,4,5] > [1:] > [2,3,4,5]
4、if T==[]:
就是已经取完了数组值,退出循环
5、x[i]>min(T)
意思就是,用1值和min([2,3,4,5])最小的值比较,就是1和2比较
如果1>2,则进行值得交换,否则不进行交换,继续下一个循环
6、t=x.index(min(T))
[3,1,2,4,5] > [x,1,2,4,5]
3>1,条件满足,则将3赋值到t变量
t=x=[3,1,2,4,5].index(min(T)) > [3,1,2,4,5].index(min([1,2,4,5])) 》[3,1,2,4,5].index(min(1)) 》[3,1,2,4,5].index(1)
意思就是1在数组[3,1,2,4,5]中得下标位置是1
也就是t=1
7、x[i],x[t]=x[t],x[i]
x[i]=x[t] 》x[0]=x[1],x[1]=x[0]
就是相互交换
完成值小的在前面,值大的在后面,就是所谓的升序排序
for i,j in enumerate(x):#从这往下就看不懂了
T=x[i+1:]//T表示当前数后面的所有数
if T==[]://找到最后了break
break
if x[i]>min(T)://如果当前数比后面所有数T中最小的大
t=x.index(min(T))//找出后面所有数T中最小的那个数的下标
x[i],x[t]=x[t],x[i]//交换当前数与后面所有数中最小的那个数
其实这个思路就是选择排序,将后面没有排序的最小(最大)放到起始位置,就是互换操作
望采纳哈哈