插入排序和归并排序
来源:互联网 发布:进口刀具刃具 知乎 编辑:程序博客网 时间:2024/04/30 07:56
我是根据算法导论中比喻来理解插入排序和归并排序
首先是插入排序,这个过程就可以比喻成左手放牌(已排好序),右手抓牌(牌堆上最顶端的一张牌),然后放到左手,插到正确的位置
伪代码
for j = 2 to A.length key = A[j]; i = j - 1; while(i >0&&a[i]<key) a[i+1] = a[i]; i --; a[i+1] = key;
可用代码
void insert(int a[],int n){ int key; int i; for (int j = 2; j <= n; j++){ key = a[j]; i = j - 1; while (i>0 && key < a[i]){ a[i + 1] = a[i]; i--; } a[i + 1] = key; }}
归并排序的思想就是,先想象成将一个数组中的n个数,假设为10,逻辑上分成两组,即a[0]-a[4]为A组,a[5]-a[10]为B组,且A组和B组各自都是排序好的数,我们首先在每组中取出第一个数比较,即(a[0]和a[5]比较大小,若a[0]小,则将a[0]插入到临时数组temp[]中,接着a[1]再和a[5]比较大小,小的一方还是放到临时数组中)。完成合并之后,再使用递归的思想,将10个数的排序分治成每一个数字,即两个数比较大小之后合并成一组,一组两个数和另外一组的两个数合并到一组中,一次类推。
public static void merge(int array[],int left,int mid,int right){ int[] temp = new int[right-left+1]; int i = left,j = mid+1,k = 0; //将一个数组通过下标分成逻辑上的两组数,比较两组数A,B,数小的放到临时数组 while(i<=mid&&j<=right){ if(array[i]<array[j]) temp[k++]=array[i++]; else{ temp[k++]=array[j++]; } } //考虑到A或B数组中的数绝大多数都比另外一个数组小,则另一个数组可能会剩下一部分排好序的数 //将剩下的数放入到数组 while(i<=mid) temp[k++] = array[i++]; while(j<=right) temp[k++] = array[j++]; //将整个临时表放到原数组中 for(int n = 0,len=temp.length;n<len;n++){ array[n+left] = temp[n]; } } //使用到递归的思想,最小会细分到一个数为一组 //然后二个数比较大小后合并成一组一组就有两个数依次类推 public static void merge_sort(int[] array, int left, int right){ int mid; if (left < right){ mid = (left + right) / 2; merge_sort(array, left, mid); merge_sort(array, mid + 1, right); merge(array, left, mid, right); } } public static void main(String[] args) { int array[] = {20,15,47,20,13,100,1}; merge_sort(array,0,array.length-1); System.out.println(Arrays.toString(array)); }
0 0
- 归并排序和插入排序
- 插入排序和归并排序
- 插入排序和归并排序
- 插入排序和归并排序
- 插入排序和归并排序
- 插入排序和归并排序
- 插入排序和归并排序
- 插入排序、归并排序
- 插入排序,归并排序
- 插入排序&归并排序
- 插入排序&&归并排序
- 插入排序和归并排序 [Algorithm]
- 算法导论:插入排序和归并排序
- c++插入排序和归并排序
- 插入排序和归并排序 [Algorithm]
- 插入排序和归并排序实现
- 比较排序之插入和归并排序
- 单链表的归并排序和插入排序
- Java设计模式——六大原则之单一原则
- HDU 1754 I Hate It 线段树
- java容器
- 致即将踏入大学校园的儿子
- arduino 呼吸灯
- 插入排序和归并排序
- 有3个字符串,要求找出其中最大者。
- 日语学习之沪江N3基础 20150623 -3
- IOS消息通信中的Notification&KVO
- Oracle Job的CRUD测试
- JDBC实例之—手机号码归属地查询(GUI版本)
- linux 笔记
- GRE高频词汇出现频率汇总
- zookeeper使用问题汇总