标签:bin 高度 术语 分治法 概念 个数 冒泡 logs 分数
算法:一个计算过程,解决问题的方法。算法是独立存在的一种解决问题的方法和思想。
算法的五大特性
时间复杂度是用来估计算法运行时间的一个式子(单位)。
时间复杂度:假设存在函数g,使得算法A处理规模为n的问题示例所用时间为T(n)=O(g(n)),则称O(g(n))为算法A的渐近时间复杂度,简称时间复杂度,记为T(n)
“大O记法”:对于单调的整数函数f,如果存在一个整数函数g和实常数c>0,使得对于充分大的n总有f(n)<=c*g(n),就说函数g是f的一个渐近函数(忽略常数),记为f(n)=O(g(n))。也就是说,在趋向无穷的极限意义下,函数f的增长速度受到函数g的约束,亦即函数f与函数g的特征相似。
排序算法(英语:Sorting algorithm)是一种能将一串数据依照特定顺序进行排列的一种算法。
冒泡排序(英语:Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
冒泡排序算法的运作如下:
def bubble_sort(li): for i in range(len(li)-1): exchange = False for j in range(len(li)-1-i): if li[j]>li[j+1]: li[j],li[j+1] = li[j+1],li[j] exchange = True if not exchange: return True
时间复杂度
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。
def select_sort(li): for i in range(len(li)-1): for j in range(i+1,len(li)): if li[i]>li[j]: li[i],li[j] = li[j],li[i]
插入排序(英语:Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。
def insert_sort(li): for i in range(1,len(li)): temp = li[i] j = i - 1 while j>=0 and li[j] > temp: li[j + 1] = li[j] j -= 1 li[j+1] = temp
快速排序(英语:Quicksort),又称划分交换排序(partition-exchange sort),通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
步骤为:
递归的最底部情形,是数列的大小是零或一,也就是永远都已经被排序好了。虽然一直递归下去,但是这个算法总会结束,因为在每次的迭代(iteration)中,它至少会把一个元素摆到它最后的位置去。
def quick_sort(li,start,end): ‘‘‘快速排序‘‘‘ #递归推出的条件 if start >= end: return #设置起始元素定位寻找位置的基准元素 mid = li[start] #low为序列左边的由左向右移的游标 low = start # high为序列右边的由右向左移的游标 high = end while low < high: # 如果low与high未重合,high指向的元素不比基准元素小,则high向左移动 while low < high and li[high] >= mid: high -= 1 # 将high指向的元素放到low的位置上 li[low] = li[high] # 如果low与high未重合,low指向的元素比基准元素小,则low向右移动 while low < high and li[low] < mid: low += 1 # 将low指向的元素放到high的位置上 li[high]= li[low] # 退出循环后,low与high重合,此时所指位置为基准元素的正确位置 # 将基准元素放到该位置 li[low] = mid # 对基准元素左边的子序列进行快速排序 quick_sort(li,start,low-1) # 对基准元素右边的子序列进行快速排序 quick_sort(li,low+1,end) li = [54,26,93,17,77,31,44,55,20] quick_sort(li,0,len(li)-1) print(li)
归并排序是采用分治法的一个非常典型的应用。归并排序的思想就是先递归分解数组,再合并数组。
将数组分解最小之后,然后合并两个有序数组,基本思路是比较两个数组的最前面的数,谁小就先取谁,取了后相应的指针就往后移一位。然后再比较,直至一个数组为空,最后把另一个数组的剩余部分复制过来即可。
def merge(left,right): l,r =0,0 result = [] while l<len(left) and r < len(right): if left[l] < right[r]: result.append(left[l]) l += 1 else: result.append(right[r]) r += 1 result += left[l:] result += right[r:] return result def merge_sort(li): if len(li)<=1: return li num = len(li)//2 print(num) left = merge_sort(li[:num]) right = merge_sort(li[num:]) return merge(left,right) print(merge_sort(li))
树(英语:tree)是一种抽象数据类型(ADT)或是实作这种抽象数据类型的数据结构,用来模拟具有树状结构性质的数据集合。它是由n(n>=1)个有限节点组成一个具有层次关系的集合。把它叫做“树”是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。它具有以下的特点:
两种特殊二叉树:
二叉树的储存方式:
链式储存;
顺序储存;
堆
堆排序过程:
def sift(data,low,high): i = low j = 2*i+1 temp = data[i] while j <= high: if j < high and data[j] < data[j+1]: j += 1 if temp < data[j]: data[i] = data[j] i = j j = 2*i + 1 else: break data[i] = temp def heap_sort(data): num = len(data) for i in range(num//2-1,-1,-1): sift(data,i,num-1) for i in range(n-1,-1,-1): data[0],data[i] = data[i],data[0] sift(data,0,i-1)
标签:bin 高度 术语 分治法 概念 个数 冒泡 logs 分数
原文地址:http://www.cnblogs.com/mona524/p/7794503.html