算法——冒泡排序、选择排序和插入排序

本文介绍了冒泡排序、选择排序和插入排序的低效时间复杂度,并通过实例展示了冒泡排序与Python内置的sorted函数在处理大规模数据时的巨大效率差距。学习者可通过这个案例理解排序算法的实际应用和性能优化。
摘要由CSDN通过智能技术生成

1、冒泡排序、选择排序和插入排序的时间复杂度都是O(n^2),效率低。

# 冒泡排序
def bubble_sort(li):
	for i in range(len(li)-1): # 第i趟
		exchange = False
		for j in range(len(li)-i-1):
			if li[j] > li[j+1]:
				li[j],li[j+1] = li[j+1],li[j]
				exchange = True
		print(li)
		if not exchange:
			return

# 选择排序
def select_sort(li):
	for i in range(len(li)-1): # 第i趟
		min_loc = i
		for j in range(i+1, len(li)):
			if li[j] < li[min_loc]:
				min_loc = j
		li[i], li[min_loc] = li[min_loc], li[i]
		print(li)

# 插入排序
def insert_sort(li):
	for i in range(1, len(li)): # i表示摸到的牌的下标
		tmp = li[i]
		j = i - 1 # j表示手里的牌的下标
		while j>=0 and li[j]>tmp:
			li[j+1] = li[j]
			j -= 1
		li[j+1] = tmp
		print(li)

li=[3,1,2,6,8,5,4,7,9]
print(li)

print('bubble_sort')
li1 = li.copy()
bubble_sort(li1)

print('select_sort')
li2 = li.copy()
select_sort(li2)

print('insert_sort')
li3 = li.copy()
insert_sort(li3)

运行结果:
在这里插入图片描述
参考文献:B站教学视频——清华计算机博士带你学习Python算法和数据结构

2、冒泡排序与sorted排序比较,后者效率高很多。

import random
import time
import copy

# 冒泡排序
def bubble_sort(li):
	for i in range(len(li)-1): # 第i趟
		exchange = False
		for j in range(len(li)-i-1):
			if li[j] > li[j+1]:
				li[j],li[j+1] = li[j+1],li[j]
				exchange = True
		if not exchange:
			return

li1 = list(range(10000))
random.shuffle(li1)
li2 = li1.copy()
print(li1[:20])
print(li2[:20])

# bubble_sort
time_start = time.time()
bubble_sort(li1)
time_end = time.time()
print('bubble_sort costs %f s' % (time_end-time_start))

# sorted
time_start = time.time()
li2 = sorted(li2)
time_end = time.time()
print('sorted costs %f s' % (time_end-time_start))

print(li1[:20])
print(li2[:20])

运行结果:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值