数据结构实验二排序算法代码实现_第1页
数据结构实验二排序算法代码实现_第2页
数据结构实验二排序算法代码实现_第3页
数据结构实验二排序算法代码实现_第4页
数据结构实验二排序算法代码实现_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、-作者xxxx-日期xxxx数据结构实验二排序算法代码实现【精品文档】#include#include #include #define MAXK 10 using namespace std;int get_int(void); int countSort (int*array,int n,int d); int get_value(int a,int d); void radixSort(int* a,int n,int d); void quickSort(int a,int,int); /选择排序 void selectionSort(int a,int n)bool sorted =

2、 false;for(int size = n;!sorted & (size1); size-)int indexOfMax = 0;sorted = true;for(int i = 1;isize; i+)if (aindexOfMax= ai)indexOfMax = i;elsesorted = false;swap(aindexOfMax,asize-1);for(int i=0;in;i+) coutai ; coutn;/冒泡排序bool bubble(int a,int n)bool swapped = false;for(int i =0;iai+1)swap(ai,ai+

3、1); swapped = true;for(int x=0;x6;x+) coutax ; cout1 & bubble(a,i);i-);/插入排序void insertionSort(int a,int n)for(int i=1;i=0 & taj;j-)aj+1=aj;aj+1=t;for(int i=0;in;i+) coutai ; coutn;/基数排序void radixSort(int* a,int n,int d) for (int i=0;i=d;i+) countSort(a,n,i); int countSort (int *array, int n,int d)

4、int kMAXK = 0; int * temp,*b; int i; temp = (int *) malloc (sizeof (int)*n); b = (int *) malloc (sizeof (int)*n); if (NULL = temp) return 0 ; for (i=0;in;i+) bi = get_value(arrayi,d); for (i = 0; i n; i+) kbi+;/记录与数组下标相等的数值的个数 for (i=1;i=0;i-) temp-kbi=arrayi; /将原数组按大小顺序储存到另一个数组 /显示temp数组 for (i=0;i

5、n;i+) printf(%d ,tempi); printf(n); for (i = 0; i 0&a0;d-) b/=MAXK; return b%MAXK; int get_int(void) int input; char ch; while (scanf(%d,&input)!=1) while(ch=getchar()!=n) putchar(input); printf( is not an integer.nPlease enter an integer value,such as 25,-178,or 3;n); return input; /快速排序 void quick

6、Sort(int s, int l, int r) if (l r) int i = l, j = r, x = sl; while (i j) while(i = x) / 从右向左找第一个小于x的数 j-; if(i j) si+ = sj; while(i j & si x) / 从左向右找第一个大于等于x的数 i+; if(i j) sj- = si; si = x; quickSort(s, l, i - 1); / 递归调用 quickSort(s, i + 1, r); /归并排序 void mergearray(int a, int first, int mid, int la

7、st, int temp) int i = first, j = mid + 1; int m = mid, n = last; int k = 0; while (i = m & j = n) if (ai = aj) tempk+ = ai+; else tempk+ = aj+; while (i = m) tempk+ = ai+; while (j = n) tempk+ = aj+; for (i = 0; i k; i+) afirst + i = tempi;void mergesort(int a, int first, int last, int temp) if (fir

8、st last) int mid = (first + last) / 2; mergesort(a, first, mid, temp); /左边有序 mergesort(a, mid + 1, last, temp); /右边有序 for (int i = 0; i last+1; +i) coutai ; coutn; mergearray(a, first, mid, last, temp); /再将二个有序数列合并for (int i = 0; i last+1; +i) coutai ; coutn; bool MergeSort(int a, int n) int *p = ne

9、w intn; if (p = NULL) return false; mergesort(a, 0, n - 1, p); delete p; return true;int main()int d6=3,2,5,1,3,4;for(int i=0;i6;i+) coutdi ; coutn;selectionSort(d,6);coutn;bubbleSort(d,6);coutn;insertionSort(d,6);coutn;int n = 12; int p12 = 323,31,13,25,2,111,332,54,253,14,544,435; for (int i=0;in;i+) printf(%d ,pi);coutn; radixSort(p,n,3); for (int i=0;in;i+) printf(%d ,pi); coutn; coutn; int array=34,65,12,43,67,5,78,10,3,70,k; int len=sizeof(array)/sizeof(int); coutThe orginal arrayare:; for(k=0;klen;k+) coutarrayk,; coutn; quickSort(array,0,len-1); coutThe sorted arrayare

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论