1.列表排序
def que6():
# 6.输入三个整数x, y, z,形成一个列表,请把这n个数由小到大输出。
# 程序分析:列表有sort方法,所以把他们组成列表即可。
li = np.random.randint(-100, 100, size=10)
# 就地转化
li = li.tolist()
# 用sort()结果
li_sort = sorted(li, reverse = False)
print('用sort方法,重新排列结果:{}'.format(li_sort))
# 不用sort方法,自己写排序方法做,
# 冒泡排序
def bubbleSort(m):
m = m.copy()
for time in range(1, len(m)):
for index in range(len(m) - time):
if m[index] > m[index+1]:
m[index], m[index+1] = m[index+1] , m[index]
return m
# 选择排序
def selectSort(m):
m = m.copy()
for seat_L in range(len(m)-1):
for seat_R in range(seat_L+1, len(m)):
if m[seat_L] > m[seat_R]:
m[seat_L], m[seat_R] = m[seat_R], m[seat_L]
return m
# 插入排序1(内部写成函数):
def insertSort_1(m):
result = []
# 单个元素k插入列表li
def to_insert(li, k):
# 标识符
tab = False
# 寻找插入位置
# 循环次数应该至少大于列表长度+1,None也占一位(空列表),即认为扑克牌最末尾还有一张‘空牌’
for i in range(len(li) + 1):
# 修改标识符,标志‘遍历完后的下一个循环’,即在和‘空牌’比较
if i == (len(li)):
tab = True
# 如果在对li[-1]比较完成(包含)之前,且寻找到位置,即把扑克从左往右比较一遍
if not tab and k < li[i]:
li.insert(i, k)
break
# 如果遍历完成,多循环一次,即和‘空牌’不需要比较,直接把牌替换掉‘空牌’
if tab:
li.append(k)
return li
# 遍历列表
# result = result[:1]
for length in range(len(m)):
result = to_insert(result, m[length])

这篇教程涵盖了Python的基础练习,包括列表排序、字典键值互换、去重、质数判断、日期计算、猜数字游戏以及进制转换,适合初学者提升技能。
最低0.47元/天 解锁文章
1603

被折叠的 条评论
为什么被折叠?



