[关闭]
@zsh-o 2018-07-29T20:44:08.000000Z 字数 829 阅读 847

堆排序

算法


堆排序的时间复杂度稳定为,并且以前对排序有点错误的认识,所以现在记录一下

  1. /**
  2. * 调整[head, end]的堆,head为父节点,使其满足堆的性质
  3. * 这个需要特别注意的是,这个地方需要满足以head为父节点左右子节点代表的子堆均满足堆序
  4. * 而且建堆的时候从一个完全无序开始,但调整的时候是从下往上开始的,故当调整完根节点之后所有的堆都调整完成
  5. * 父节点不满足,当调整父节点和左右子节点这三个节点之后,再调整破坏了的子堆结构即可
  6. * 这时只需把不满足的父节点每级向下沉即可,沉的过程不破坏当前调整的三个节点的未改变的那个节点的子堆结构
  7. */
  8. #include <stdio.h>
  9. #include <string.h>
  10. void _swap(int& a, int& b){
  11. int t = a;
  12. a = b;
  13. b = t;
  14. }
  15. void adjMaxHeap(int* A, int left, int right){
  16. int i = left;
  17. while(i <= right / 2){
  18. int lc = (i<<1);
  19. int rc = (i<<1) + 1;
  20. int t = 0; //记录当前最大的下标
  21. if((rc > right) || (A[lc - 1] > A[rc - 1])){
  22. t = lc;
  23. }else{
  24. t = rc;
  25. }
  26. if(A[t - 1] > A[i - 1]){
  27. _swap(A[t-1], A[i - 1]);
  28. i = t;
  29. }else{
  30. return;
  31. }
  32. }
  33. }
  34. int* heapSort(int* A, int n){
  35. // 构建大顶堆
  36. for(int i=n/2; i>1; i--){
  37. adjMaxHeap(A, i, n);
  38. }
  39. for(int i=n; i>1; i--){
  40. adjMaxHeap(A, 1, i);
  41. _swap(A[0], A[i-1]);
  42. }
  43. return A;
  44. }
  45. int main(){
  46. int A[] = {7,4,5,8,2,6,1,4};
  47. int l = sizeof(A) / sizeof(int);
  48. heapSort(A, l);
  49. for(int i=0; i<l; i++){
  50. printf("%d ", A[i]);
  51. }
  52. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注