lowB三人组代码示例
冒泡排序:列表在内存重只存一份,所以不需要重复赋值
import random
from timewrap import * #时间装饰器
# 初级版本
@cal_time
def bubble_sort(li):
for i in range(len(li)-1): #循环的躺数为总的躺数-1,因为最后一步没必要走
# i 表示趟数
# 第 i 趟时: 无序区:(0,len(li) - i)
for j in range(len(li) - i - 1): #循环i次之后就还有总长度-1-i次
if li[j] > li[j+1]: #如果低j个数比j+1个数还要大,说明j在j+1的上边
li[j], li[j+1] = li[j+1], li[j] #交换位置
# 优化版,和上边的基本一样,只是在他的基础上增加了一层判断,如果刚刚开始列表就是有序的则不需要进行排序
@cal_time
def bubble_sort_2(li):
for i in range(len(li)-1):
# i 表示趟数
# 第 i 趟时: 无序区:(0,len(li) - i)
change = 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]
change = True #排序成功返回True
if not change: #如果没有change的值代表没有排序,
return li = list(range(10000)) #随机产生10000个数
# random.shuffle(li) #打乱后的结果
# print(li)
bubble_sort_2(li) #没有打乱排序,直接走if not change:
print(li)
#选择排序
import random
from timewrap import * #时间装饰器,用来判断函数执行的时间长度 @cal_time
def select_sort(li):
for i in range(len(li)-1):
# i 表示趟数,也表示无序区开始的位置
min_loc = i # 最小数的位置 的到一个最小值
for j in range(i+1, len(li)): #此时i就是最小值
if li[j] < li[min_loc]: #如果li[j]<li[min_loc] 说明j就是最小值
min_loc = j
li[i], li[min_loc] = li[min_loc], li[i] #交换位置,最小值放在前边 li = list(range(10000)) #随机产生1000个数字
random.shuffle(li) #打乱
print(li)
select_sort(li) #调用函数,排序
print(li)
#插入排序
import random
from timewrap import * @cal_time
def insert_sort(li):
for i in range(1, len(li)):
# i 表示无序区第一个数
tmp = li[i] # 摸到的牌 随机去到一支歌
j = i - 1 # j 指向有序区最后位置
while li[j] > tmp and j >= 0: # 有序区最下的值
#循环终止条件: 1. li[j] <= tmp; 2. j == -1
li[j+1] = li[j]
j -= 1
li[j+1] = tmp li = list(range(10000))
random.shuffle(li)
print(li)
insert_sort(li)
print(li)
lowB三人组代码示例的更多相关文章
- 算法 排序lowB三人组 冒泡排序 选择排序 插入排序
		参考博客:基于python的七种经典排序算法 [经典排序算法][集锦] 经典排序算法及python实现 首先明确,算法的实质 是 列表排序.具体就是操作的列表,将无序列表变成有序列表! 一 ... 
- 1、算法介绍,lowB三人组,快速排序
		1.什么是算法 2.递归 # 一直递归,递归完成再打印 def func4(x): if x > 0: func4(x - 1) print(x) func4(5) 3.时间 复杂度 (1)引入 ... 
- lowB三人组算法-冒泡排序-选择排序-插入排序
		冒泡排序 时间复杂度:O(n2) 算法稳定 第一趟,从第一个数开始,相邻两个数比较,大的数交换放后,交换到最后位置得出一个第一大数 第二趟,从第一个数开始,相邻两个数比较,大的数交换放后,交换到倒数 ... 
- 算法排序-lowB三人组
		冒泡排序思路: 选择排序思路: 插入排序思路: 小结: 详细代码解释看下一篇 
- 算法之LOWB三人组之插入排序
		插入排序 思想:类似于抽扑克牌,共有8张扑克牌,手里默认有一张,桌面上有7张,我们每次从桌面上抽一张和手里的牌进行比较,如果比手里的牌大,则直接放到手里的牌的后面,如果比手里的牌小,则放到手里的牌的前 ... 
- 算法之LOWB三人组之选择排序
		选择排序 思想是在一个列表中每次循环一遍,拿到最小值,接着再从剩下的无序区中继续拿最小值,如此循环,直到结束. 时间复杂度为O(n^2) # 最简单的一个选择排序,循环一个列表,拿到最小值,添加到一个 ... 
- 算法之LOWB三人组之冒泡排序
		排序 冒泡排序(Bubble Sort)时间复杂度为O(n^2) 列表每两个相邻的数,如果前面比后面大,则交换这两个数 一趟排序完成后,则无序区减少一个数,有序区增加一个数. def bubble_s ... 
- 排序算法lowb三人组-插入排序
		def insert_sort(li): for i in range(1, len(li)): # i表示摸到的牌的下标 tmp = li[i] # 摸到的牌 j = i - 1 while j & ... 
- 排序算法lowb三人组-选择排序
		def get_min_pos(li): min_pos = 0 for i in range(1, len(li)): if li[i] < li[min_pos]: min_pos = i ... 
随机推荐
- 大杂烩 Classpath / Build path / Debug关联源码 / JDK&JRE区别
			Classpath的理解及其使用方式 原文地址:http://blog.csdn.net/wk1134314305/article/details/77940147?from=bdhd_site 摘要 ... 
- 【前端学习笔记】2015-09-01 附二  关于jq选择器的简单运用
			根据id来选择------$("#id") 根据class来选择------$(".classname") 根据tag来选择-------$("tag ... 
- SQL的主键和外键和唯一约束
			SQL的主键和外键的作用: 外键取值规则:空值或参照的主键值. (1)插入非空值时,如果主键表中没有这个值,则不能插入. (2)更新时,不能改为主键表中没有的值. (3)删除主键表记录时,你可以在建外 ... 
- VMware锁定文件失败开启模块diskearly的操作失败未能启动虚拟机
			删除虚拟机目录下的(如图中标明的就是D:\VMWorks\YeZiZxWeb这个目录)三个 *.lck文件夹,启动正常 
- 一款手机端的日历插件ICalendar.js
			我的网盘:http://pan.baidu.com/s/1jIib2Ay 
- 搭建redis集群时所遇问题及解决方法
			单独一台虚拟机(系统CentOS 7) 问题1 创建redis集群环境时,输入以下命令 [root@localhost redis-cluster]# ./redis-trib.rb create - ... 
- ScrollView 嵌套WebView 的问题优化
			一.布局样式 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:androi ... 
- E. Sergey and Subway
			比赛时候写复杂了…… 我写的是 计算每个节点树内所有点到某个点的距离和. #include <bits/stdc++.h> using namespace std; typedef lon ... 
- BZOJ 3309 莫比乌斯反演
			题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=3309 题意:定义f(n)为n所含质因子的最大幂指数,求 $Ans=\sum _{i=1} ... 
- UVA 10635 Prince and Princess【LCS 问题转换为 LIS】
			题目链接: http://acm.hust.edu.cn/vjudge/problem/visitOriginUrl.action?id=19051 题意: 有两个长度分别为p+1和q+1的由1到n2 ... 
