转载:http://blog.csdn.net/pzhtpf/article/details/7560312
7、归并排序
(1)基本排序:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。
(2)实例:
(3)用java实现
- import java.util.Arrays;
- public class mergingSort {
- int a[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34,15,35,25,53,51};
- public mergingSort(){
- sort(a,0,a.length-1);
- for(int i=0;i<a.length;i++)
- System.out.println(a[i]);
- }
- public void sort(int[] data, int left, int right) {
- // TODO Auto-generated method stub
- if(left<right){
- //找出中间索引
- int center=(left+right)/2;
- //对左边数组进行递归
- sort(data,left,center);
- //对右边数组进行递归
- sort(data,center+1,right);
- //合并
- merge(data,left,center,right);
- }
- }
- public void merge(int[] data, int left, int center, int right) {
- // TODO Auto-generated method stub
- int [] tmpArr=new int[data.length];
- int mid=center+1;
- //third记录中间数组的索引
- int third=left;
- int tmp=left;
- while(left<=center&&mid<=right){
- //从两个数组中取出最小的放入中间数组
- if(data[left]<=data[mid]){
- tmpArr[third++]=data[left++];
- }else{
- tmpArr[third++]=data[mid++];
- }
- }
- //剩余部分依次放入中间数组
- while(mid<=right){
- tmpArr[third++]=data[mid++];
- }
- while(left<=center){
- tmpArr[third++]=data[left++];
- }
- //将中间数组中的内容复制回原数组
- while(tmp<=right){
- data[tmp]=tmpArr[tmp++];
- }
- System.out.println(Arrays.toString(data));
- }
- }
8、基数排序
(1)基本思想:将所有待比较数值(正整数)统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后,数列就变成一个有序序列。
(2)实例:
(3)用java实现
- import java.util.ArrayList;
- import java.util.List;
- public class radixSort {
- int a[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,101,56,17,18,23,34,15,35,25,53,51};
- public radixSort(){
- sort(a);
- for(int i=0;i<a.length;i++)
- System.out.println(a[i]);
- }
- public void sort(int[] array){
- //首先确定排序的趟数;
- int max=array[0];
- for(int i=1;i<array.length;i++){
- if(array[i]>max){
- max=array[i];
- }
- }
- int time=0;
- //判断位数;
- while(max>0){
- max/=10;
- time++;
- }
- //建立10个队列;
- List<ArrayList> queue=new ArrayList<ArrayList>();
- for(int i=0;i<10;i++){
- ArrayList<Integer> queue1=new ArrayList<Integer>();
- queue.add(queue1);
- }
- //进行time次分配和收集;
- for(int i=0;i<time;i++){
- //分配数组元素;
- for(int j=0;j<array.length;j++){
- //得到数字的第time+1位数;
- int x=array[j]%(int)Math.pow(10, i+1)/(int)Math.pow(10, i);
- ArrayList<Integer> queue2=queue.get(x);
- queue2.add(array[j]);
- queue.set(x, queue2);
- }
- int count=0;//元素计数器;
- //收集队列元素;
- for(int k=0;k<10;k++){
- while(queue.get(k).size()>0){
- ArrayList<Integer> queue3=queue.get(k);
- array[count]=queue3.get(0);
- queue3.remove(0);
- count++;
- }
- }
- }
- }
- }
相关推荐
数据结构排序选择排序归并排序基数排序PPT学习教案.pptx
C# 插入排序 冒泡排序 选择排序 快速排序 堆排序 归并排序 基数排序 希尔排序
数据结构课件:第10章 排序2选择排序归并排序基数排序.pptx
本章主要介绍一些常用的排序算法:插入排序、交换排序、选择排序、归并排序和基数排序。这里介绍的排序算法都是基于待排序的数据元素序列构成的线性表采用顺序存储结构,即采用数组存储,并且默认为按关键字非递减...
数据结构归并排序、基数排序讲解分析 word格式的
2.归并排序;3.基数排序。 北工大电控学院《数据结构与算法》课程的其它章节实验及作业程序代码亦已在本站上传,需要的同学可进入作者的空间或通过搜索获取。本代码为上传者原创,仅供个人学习参考使用,请勿自行在...
作业24-归并排序与基数排序.docx 作业24-归并排序与基数排序.docx ...作业24-归并排序与基数排序.docx作业24-归并排序与基数排序.docx作业24-归并排序与基数排序.docx作业24-归并排序与基数排序.docx
插入排序、选择排序、希尔排序、堆排序、冒泡、双向冒泡、快速排序、归并排序、递归的归并排序、基数排序
试通过随机数据比较归并排序、基数排序各算法的关键字比较次数和关键字移动次数。 (1)待排序表的表长不小于100;其中的数据要用伪随机数产生程序产生;至少要用5组不同的输入数据作比较;比较的指标为有。关键字...
选择排序,冒泡排序,插入排序 基数排序,快速排序,归并排序
快速排序、归并排序、基数排序等排序算法比较,比较时间性能,采用C++语言实现。。。
C语言所有排序大全,解决了您日常上课考试学习的需要,在这里每一个程序都没有错误,其中压缩包包括了归并排序;基数排序;快速排序;冒泡排序;选择排序;折半排序;希尔排序这些日常排序,因为是全集所以大家踊跃...
"直接插入排序"," 折半插入排序"," 2—路插入排序"," 表插入排序"," 希尔排序"," 起泡排序"," 快速排序"," 简单选择排序"," 树形选择排序"," 堆排序"," 归并排序"," 链式基数排序。 基本要求: 待排序表的表长不...
这样会不会太邪恶了 基数排序根本没有关键字比较 题目有错滴
采用c++描述了各种排序算法,包括选择排序 冒泡排序 插入排序 基数排序 快速排序 归并排序 。实验内容 1、创建排序类。 2、提供操作:选择排序、冒泡排序、插入排序、*基数排序、*快速排序、*归并排序。 3、*能够...
源程序给出了插入排序、选择排序、希尔排序、堆排序、冒泡、双向冒泡、快速排序、归并排序、递归的归并排序、基数排序等多种排序算法,其中有17处需要填空。
简单的十大排序,c++代码实现,堆,冒泡,快速,计数,基数,归并,简单排序等
C_算法源码(冒泡排序+基数排序+插入排序+快速排序+归并排序 C_算法源码(冒泡排序+基数排序+插入排序+快速排序+归并排序 C_算法源码(冒泡排序+基数排序+插入排序+快速排序+归并排序 C_算法源码(冒泡排序+基数排序+...
插入排序、冒泡排序、归并排序、快速排序四种排序方式的C++实现,各写成了一个函数,主函数中可以选择调用那一个。初始化数组时用的是随机种子srand((int)time(0))。在宏中定义数组大小。