1、排序算法
2、列表查找
从列表中查找指定的元素
从列表第一个元素开始,顺序进行搜索,直到找到为止
从有序列表的候选区data[0: n]开始,通过对待查找的值与候选区中的值比较使候选区的值减半
时间复杂度:程序执行的大概次数,使用O()来计
logn == log2^n
如何一眼判断时间复杂度:
1. 循环减半的过程 ==》O(logn)
2. 几次循环就是n的几次方的复杂度
用来评估算法内存占用大小的一个式子
首先列表每相邻两个数进行比较,如果前面的比后面的大,就交换两个数
# 冒泡排序 # 时间复杂度:O(n^2) def bubble_sort(li): for i in range(len(li) - 1): # 趟数 flag = True for j in range(len(li) - 1 - i): # 每一趟内层循环,每一趟确定一个比较次数-i if li[j] > li[j + 1]: # 前面大于后面交换位置 li[j], li[j + 1] = li[j + 1], li[j] flag = False if flag: # 优化:如果一趟循环下来都没有要比较交换的位置说明原本就是顺序的,直接返回 return
先选择一个数,默认该数是最小的放在第一的位置,然后再一次遍历取出所有的数与第一个数比较,如果比他大交换位置
# 选择排序 # 时间复杂度:O(n^2) def select_sort(li): for i in range(len(li)): # 将取出的第一个默认是最小的 minloc = i for j in range(i + 1, len(li)): # 循环比较后面的所有值与 第一个元素比较 if li[minloc] > li[j]: # 如果比第一个元素小就换位置 li[minloc], li[j] = li[j], li[minloc]
列表被分为有序区域无序区两个部分,最初有序区就一个元素,每次从无序区取出一个元素,插入到有序区的位置,直到无序区变空
# 插入排序 # 时间复杂度:O(n^2) def insert_sort(li): # 将第一个元素作为有序区第一个元素 for i in range(1, len(li)): # 将无序区中的元素取出拿一个变量存着 tmp = li[i] # 获取取去的前一个元素的索引 j = i - 1 # 比较取出的元素与前面的所有元素 while j >= 0 and li[j] > tmp: # 前面的值覆盖取出的值 li[j + 1] = li[j] # 依次循环前面的所有值 j = j - 1 # 比较完j=-1跳出循环,将取出的值作为第一个 li[j + 1] = tmp
取一个元素p(第一个元素),使p其归位,列表被p分为两部分,左边的都比p小,右边的比p大,最后递归完成排序
# 快速排序 # 时间复杂度:O(nlogn) def quick_sort(li, left, right): # left与right是左右两边的索引 if left < right: # 调用归为函数得到中间的索引 mid = partition(li, left, right) # 递归减半左右两边 quick_sort(li, left, mid-1) quick_sort(li, mid+1, right) # 归为函数 def partition(li, left, right): # 将第一个元素取出 tem = li[left] while left < right: # 判断右边的是否比取出的第一个元素大,如果大指针移动一位 while left < right and li[right] >= tem: right = right - 1 # 如果右边的比第一个小,将该元素赋值给左边 li[left] = li[right] # 判断左边的元素是否比取出的元素小,如果小指针移动一位 while left < right and li[left] <= tem: left = left + 1 # 如果左边的比取出的大,将该元素赋值给刚右边元素的位置 li[right] = li[left] # 当指针重合时,将取出的第一个元素放下在中间 li[left] = tem mid = left # 或者等于right,两边指针重合时 return mid # quick_sort(li, 0, len(li)-1)
1、线性结构
2、非线性结构
原文:https://www.cnblogs.com/Mr-shen/p/12622927.html