python中使⽤Random随机⽣成列表的⽅法
引⾔:闲来想到冒泡排序中的列表数据的排序,就想试试⽤随机数⽣成⼀个列表来排序试试,于是做了⼀下实验,本⼈实在是属于⼊门阶段,研究了⼀下终究还是完成了
1.在python中⽤random⽣成⼀个列表。
(0,1000)指列表中的数取值范围0~1000之间,list列表数的lenth=10。
import random
list=[random.randint(0,1000)for i in range(10)]
print(list)
输出结果如图:
但是这种⽅法取值是可以重复的,
import random
list=[random.randint(0,10)for i in range(10)]
print(list)
2.翻了⼀些资料到了取值不重复的写法
range(10)是取值范围,后⾯的值是lenth长度
import random
list=random.sample([i for i in range(0,10)],10)
print(list)
输出如下:
3.下⾯⽤冒泡排序来实验⼀下效果
import random#导⼊随机数的包
list=random.sample([i for i in range(0,10)],10)#确定随机取值的范围和列表l的长度
print(list)
#获取列表的长度
n=len(list)
#冒泡排序
#外循环每次循环就会两两⽐较选出最⼤的数放在右边,所以是实际⽐较的个数是n-1(⽐如1,2,3)三个数⽐较只会⽐较2次,外循环控制循环多少趟
for x in range(0,n-1):
# 内循环控制每趟循环的次数,每趟循环就会两两⽐较选出最⼤的数放在右边,选出的数(x)不计⼊次数,且每次⽐较都会(n-1次),所以是长度n-x-1 for y in range(0,n-1-x):
#如果左边的数⼤于右边的数就会交换位置,⽤到赋值交换
if list[y]>list[y+1]:
be=list[y]
list[y]=list[y+1]
list[y+1]=be
print(list)
输出结果:
下⾯我换换print输出的位置我们就可以看见⽐较的过程
import random
list=random.sample([i for i in range(0,10)],10)python生成1到100之间随机数
print(list)
n=len(list)
for x in range(0,n-1):
for y in range(0,n-1-x):
if list[y]>list[y+1]:
be=list[y]
list[y]=list[y+1]
list[y+1]=be
print(list)
降序的写法
import random#导⼊随机数的包
list=random.sample([i for i in range(0,10)],10)#确定随机取值的范围和列表l的长度
print(list)
#获取列表的长度
n=len(list)
#冒泡排序
#外循环每次循环就会两两⽐较选出最⼤的数放在右边,所以是实际⽐较的个数是n-1(⽐如1,2,3)三个数⽐较只会⽐较2次
for x in range(0,n-1):
# 内循环控制每趟循环的次数,每趟循环就会两两⽐较选出最⼤的数放在右边,选出的数(x)不计⼊次数,且每次⽐较都会(n-1次),所以是长度n-x-1 for y in range(0,n-1-x):
#如果左边的数⼤于右边的数就会交换位置,⽤到赋值交换
if list[y]<list[y+1]:
be=list[y]
list[y]=list[y+1]
list[y+1]=be
print(list)
输出结果:
本⼈⽔平太过于⼀般,⼊⾏不久,有错误的地⽅希望⼤佬们给出建议,及时修正。坚持进步,路漫漫~~共勉>-<
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论