您好,登录后才能下订单哦!
小编给大家分享一下c语言常用的排序算法有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
基本思想:插入排序就是每一步都将一个待排数据按其大小插入到已经排序的数据中的适当位置,直到全部插入完毕。
void insertSort(vector<int>& nums) { int k = 0; for (int i = 0; i < nums.size(); ++i) { int temp = nums[i]; int j = i; for (; j > 0 && temp < nums[j-1]; --j) nums[j] = nums[j-1]; nums[j] = temp; } }
基本思想:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,然后依次缩减增量再进行排序,待整个序列中的元素基本有序(增量足够小)时,再对全体元素进行一次直接插入排序。因为直接插入排序在元素基本有序的情况下(接近最好情况),效率是很高的,因此希尔排序在时间效率上比前两种方法有较大提高。
void shellSort(vector<int>& nums) { for (int gap = nums.size() / 2; gap > 0; gap /= 2) { for (int i = gap; i < nums.size(); ++i) { int temp = nums[i]; int j = i; for (; j >=gap && temp < nums[j-gap]; j -= gap) nums[j] = nums[j - gap]; nums[j] = temp; } } }
用一句概括,堆排序就是一种改进的选择排序,改进的地方在于,每次做选择的时候,不单单把最大的数字选择出来,而且把排序过程中的一些操作进行了记录,这样在后续排序中可以利用,并且有分组的思想在里面,从而提高了排序效率,其效率为O(n*logn).
#include<stdio.h> int c=0; /*heapadjust()函数的功能是实现从a[m]到a[n]的数据进行调整,使其满足大顶堆的特性*/ /*a[]是待处理的数组,m是起始坐标, n是终止坐标*/ void heapadjust(int a[], int m, int n) { int i, temp; temp=a[m]; for (i=2*m;i<=n;i*=2)//从m的左孩子开始 { if(i+1<=n && a[i]<a[i+1])//如果左孩子小于右孩子,则将i++,这样i的值就是最大孩子的下标值 { i++; } if(a[i]<temp)//如果最大的孩子小于temp,则不做任何操作,退出循环;否则交换a[m]和a[i]的值,将最大值放到a[i]处 { break; } a[m]=a[i]; m=i; } a[m]=temp; } void crtheap(int a[], int n)//初始化创建一个大顶堆 { int i; for (i=n/2; i>0; i--)//n/2为最后一个双亲节点,依次向前建立大顶堆 { heapadjust(a, i, n); } } /*swap()函数的作用是将a[i]和a[j]互换*/ void swap(int a[], int i, int j) { int temp; temp=a[i]; a[i]=a[j]; a[j]=temp; c++; } void heapsort(int a[], int n) { int i; crtheap(a, n); for (i=n; i>1; i--) { swap(a, 1, i); //将第一个数,也就是从a[1]到a[i]中的最大的数,放到a[i]的位置 heapadjust(a, 1, i-1); //对剩下的a[1]到a[i],再次进行堆排序,选出最大的值,放到a[1]的位置 } } int main(void) { int i; int a[10]={-1,5,2,6,0,3,9,1,7,4}; printf("排序前:"); for (i=1;i<10;i++) { printf("%d",a[i]); } heapsort(a, 9); printf("\n\n共交换数据%d次\n\n", c); printf("排序后:"); for (i=1;i<10;i++) { printf("%d",a[i]); } printf("\n\n\n"); return 0; }
基本思想:归并排序是利用递归和分而治之的技术将数据序列划分成为越来越小的半子表,再对半子表排序,最后再用递归步骤将排好序的半子表合并成为越来越大的有序序列,归并排序包括两个步骤,分别为:
1)划分子表
2)合并半子表
刚好最近刷leetcode有道题用的归并排序:sort list
class Solution { public: //归并排序 ListNode* getMiddleOfList(ListNode* head) { ListNode* mid = head; ListNode* last = head; while (last->next!=NULL&&last->next->next!=NULL) { mid = mid->next; last = last->next->next; } return mid; } ListNode* sortList(ListNode* head) { if (head == NULL || head->next == NULL)return head; ListNode* mid = getMiddleOfList(head); ListNode* midnext = mid->next; mid->next = NULL; return mergeList(sortList(head), sortList(midnext)); } ListNode* mergeList(ListNode* a, ListNode* b) { ListNode* res = new ListNode(-1); ListNode* cur = res; while (a != NULL&&b != NULL) { if (a->val < b->val) { cur->next = a; a = a->next; } else { cur->next = b; b = b->next; } cur = cur->next; } cur->next = a != NULL ? a : b; return res->next; } };
基本思想:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,然后依次缩减增量再进行排序,待整个序列中的元素基本有序(增量足够小)时,再对全体元素进行一次直接插入排序。因为直接插入排序在元素基本有序的情况下(接近最好情况),效率是很高的,因此希尔排序在时间效率上比前两种方法有较大提高。
class sort { public: int median3(vector<int>& nums, int left, int right) { int mid = (left + right) / 2; if (nums[left] > nums[mid])swap(nums[left], nums[mid]); if (nums[mid] > nums[right])swap(nums[mid], nums[right]); if (nums[left] > nums[mid])swap(nums[left], nums[mid]); swap(nums[mid], nums[left]); return nums[left]; } void quickSort(vector<int>& nums, int i, int j) { if (i > j)return; int partition = median3(nums, i, j); int low = i+1, high = j; while (low < high) { while (nums[low] < partition)low++; while (nums[high] > partition)high--; if (low < high)swap(nums[low], nums[high]); else break; } swap(nums[i], nums[high]); quickSort(nums, i, high - 1); quickSort(nums, high + 1, j); } void qs(vector<int>& nums) { quickSort(nums, 0, nums.size() - 1); } };
以上是“c语言常用的排序算法有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。