时间:2021-05-20
本文实例讲述了C语言基本排序算法之桶式排序。分享给大家供大家参考,具体如下:
桶式排序是对一个有n个整型元素的数组a[n],其中对任意i,0 <= a[i] <= m的特殊排序算法。
可以对 n==m, n != m分别处理。写代码时需要注意的的是a[i]是访问第i-1个元素,而非第i个。
/************************************************************************************//************************************************************************************/#include <vector>void Bucket_Sort_m(int *a, int n, int m){ std::vector<int> temp(m,0); int i; for(i = 0; i != n; ++i) //遍历a[] ++temp[a[i]-1]; //如果有对应于下标的值,标记为1,否则为0 i = 0; for(int j = 1; j <= m; ++j) //遍历temp向量 if(temp[j-1]) a[i++] = j; temp.clear();}void Bucket_Sort(int *a,int n){ for(int i = 1; i <= n; ++i) { while(a[i-1] != i) { int temp = a[a[i-1]-1]; a[a[i-1]-1] = a[i-1]; a[i-1] = temp; } }}希望本文所述对大家C语言程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C语言基本排序算法之插入排序与直接选择排序实现方法。分享给大家供大家参考,具体如下:声明待排序元素类型/*--------------------
本文实例讲述了C语言基本排序算法之shell排序。分享给大家供大家参考,具体如下:shell排序是对直接插入方法的改进方法./*----------------
本文实例讲述了C语言排序算法之冒泡排序实现方法。分享给大家供大家参考,具体如下:冒泡排序和改进的冒泡排序/*--------------------------
C++算法之希尔排序算法详解及实例希尔排序算法定义:希尔排序是插入排序的一种,也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。算法思想:希尔排序是把
本文实例讲述了Python数据结构与算法之常见的分配排序法。分享给大家供大家参考,具体如下:箱排序(桶排序)箱排序是根据关键字的取值范围1~m,预先建立m个箱子