• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

C语言实现选择排序、冒泡排序和快速排序的代码示例

c语言 搞代码 4年前 (2022-01-06) 74次浏览 已收录 0个评论

这篇文章主要介绍了C++中实现选择排序、冒泡排序和快速排序的代码示例,例子带有执行时间统计还可以简单看一下效率对比,需要的朋友可以参考下

选择和冒泡

 #include void maopao(int a[],int len)<strong style="color:transparent">来源gaodai#ma#com搞@@代~&码网</strong>{ int i,j,temp; for(i = 0;i  a[j + 1])//大的数换到后面去 { temp = a[j]; a[j] = a[j + 1]; a [j + 1] = temp; } } } } void xuanze(int a[],int len){ int i , j , t , temp; for (i = 0 ; i <len - 1 ;i ++) { t=i; for (j=i + ; j  a[j]) { t = j;//记下该趟最小数的序号 } } if (t != i)//如果序号不变就什么也不做 { temp = a[t];//否则元素交换 a[t] = a[i]; a[i] = temp; } } } void main(){ int i; int a[] = {5,4,6,7,2,5,4,6,8,9,1,2}; //maopao(a, 12); xuanze(a, 12); for (i = 0 ; i <12 ; i ++) { printf("%d ",a[i]); } <pre></div><p> <br />  <br /> 快速排序与冒泡、选择的比较:<br /></p><div class="gaodaimacode"><pre class="prettyprint linenums"> #include  #include  #include  //快速排序,参数是数组,最低索引,最高索引(从0开始) void qSort(int a[], int low, int high){ int temp; int mid = low;//定义一个中索引,用于记录一次排序后确定位置的一个元素索引 int right = high;//记录最右元素索引 //默认中值是左值,现在要把凡是比中值大的元素放到中值左边 while(right > mid){//因此从右开始向中值遍历,到达中值时遍历结束 if (a[right]  1)//如果low到mid之间还有两个或以上元素,还要对他们排序 { qSort(a, low, mid - 1); } if (high - mid > 1)//右边那半也是一样 { qSort(a, mid + 1, high); } } void sSort(int a[], int len){//选择排序,参数是数组名和元素个数 int i, j, m, temp; for (i = 0; i  a[j + 1])//如果元素比他的后一个大,则交换 { temp = a[j]; a[j] = a[j + 1]; a[j + 1] = temp; } }//一次遍历后最大元素放到最后面 } } int checkSorted(int a[], int len){//检查数组排序是否已经正确 int i; for (i = 0; i  a[i + 1])//如果一个元素比他的下一个还要大,说明发生错误 { return 0; } } return 1; } void main(){ int i, j; int a[99999]; clock_t begin, end; double cost; for (j = 0; j <6; j++)//做6次测试 { srand((int)time(0));//用时间做种,是每次数字都不同 for (i = 0; i <99999; i++) { a[i] = rand();//产生随机数放入数组 } begin = clock(); //qSort(a, 0, 99998);//1秒左右 //sSort(a, 99999);//20秒左右 mSort(a, 99999);//40秒左右 end = clock(); for (i = 0; i <12; i++)//输出前面的几个排好序的元素 { printf("%d ", a[i]); } cost = (double)(end - begin) / CLOCKS_PER_SEC;//计算排序时间 printf("...\t排序用时 %lf 秒 ", cost);//输出排序所用时间 if (checkSorted(a, 99999))//检查排序是否正确 { printf("正确!\n"); }else{ printf("有错!\n"); } Sleep(1200);//暂停一下,使每次时间种子不同 } } 

1. 快速排序的结果:
 99999个随机数一般不超过0.05秒,很快
2.选择法排序结果:

 99999个随机数一般不超过0.05秒,很快
2.选择法排序结果:

一般在20多秒;
3.冒泡法,一般情况下交换的次数会很多,结果:

排序时间一般在50秒左右,最慢。
 
在C++中,还可以定义函数模板
因为快速排序通常很快,所以用它来对不同的数据类型排序

 #include  template void qSort(T a[], int low, int high){//在C++中,可以定义函数模板 T temp; int mid = low; int right = high; while (right > mid) { if (a[right]  1) { qSort(a, low, mid - 1); } if (high - mid > 1) { qSort(a, mid + 1, high); } } void main(){ int a[10] = {1, 9, 6, 3, 5, 7, 1};//有了一个函数模板,可以对整型排序 qSort(a, 0, 9); for (int i = 0; i <10; i++) { cout<

以上就是C语言实现选择排序、冒泡排序和快速排序的代码示例的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:C语言实现选择排序、冒泡排序和快速排序的代码示例
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址