1
0

sorts.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. //
  2. // Created by 李洋 on 2023/10/19.
  3. //
  4. #ifndef LEECODE_C_SHELLSORT_H
  5. #define LEECODE_C_SHELLSORT_H
  6. #include <vector>
  7. #include <random>
  8. #include <iostream>
  9. using namespace std;
  10. void shellSort(vector<int> &arr) {
  11. int n = arr.size();
  12. // 选择增量序列,可以根据需要选择不同的序列
  13. for (int gap = n / 2; gap > 0; gap /= 2) {
  14. // 使用插入排序对每个子数组进行排序
  15. for (int i = gap; i < n; ++i) {
  16. int temp = arr[i];
  17. int j = i;
  18. while (j >= gap && arr[j - gap] > temp) {
  19. arr[j] = arr[j - gap];
  20. j -= gap;
  21. }
  22. arr[j] = temp;
  23. }
  24. }
  25. }
  26. // 快速排序 - start
  27. int partition(vector<int> &arr,int left,int right){
  28. int sign = arr[left];
  29. while(left < right){
  30. while(left < right && sign <= arr[right]){
  31. right--;
  32. }
  33. swap(arr[left],arr[right]);
  34. while(left < right && arr[left] <= sign){
  35. left++;
  36. }
  37. swap(arr[left],arr[right]);
  38. }
  39. return left;
  40. }
  41. void splits(vector<int> &arr,int left,int right){
  42. if (left < right)
  43. {
  44. int norm = partition(arr,left,right);
  45. splits(arr,left,norm - 1);
  46. splits(arr,norm + 1,right);
  47. }
  48. }
  49. void quickSort(vector<int> &arr) {
  50. splits(arr, 0, arr.size() - 1);
  51. }
  52. // 快速排序 - end
  53. // 堆排序 - start small -> large
  54. void maxHeapify(vector<int> &arr, int n, int i) {
  55. int largest = i;
  56. int left = i * 2 + 1;
  57. int right = i * 2 + 2;
  58. if (left < n && arr[left] > arr[largest]) {
  59. largest = left;
  60. }
  61. if (right < n && arr[right] > arr[largest]) {
  62. largest = right;
  63. }
  64. if (largest != i) {
  65. swap(arr[i], arr[largest]);
  66. maxHeapify(arr, n, largest);
  67. }
  68. }
  69. void heapSort(vector<int> &arr) {
  70. auto n = arr.size();
  71. for (int i = n / 2 - 1; i >= 0; --i) {
  72. maxHeapify(arr, n, i);
  73. }
  74. for (int i = n - 1; i > 0; i--) {
  75. swap(arr[0], arr[i]);
  76. maxHeapify(arr, i, 0);
  77. }
  78. }
  79. // 堆排序 - end small -> large
  80. // 归并排序
  81. void merge(std::vector<int>& arr, int left, int middle, int right) {
  82. int n1 = middle - left + 1;
  83. int n2 = right - middle;
  84. std::vector<int> leftArr(n1);
  85. std::vector<int> rightArr(n2);
  86. for (int i = 0; i < n1; i++) {
  87. leftArr[i] = arr[left + i];
  88. }
  89. for (int i = 0; i < n2; i++) {
  90. rightArr[i] = arr[middle + 1 + i];
  91. }
  92. int i = 0, j = 0, k = left;
  93. while (i < n1 && j < n2) {
  94. if (leftArr[i] <= rightArr[j]) {
  95. arr[k] = leftArr[i];
  96. i++;
  97. } else {
  98. arr[k] = rightArr[j];
  99. j++;
  100. }
  101. k++;
  102. }
  103. while (i < n1) {
  104. arr[k] = leftArr[i];
  105. i++;
  106. k++;
  107. }
  108. while (j < n2) {
  109. arr[k] = rightArr[j];
  110. j++;
  111. k++;
  112. }
  113. }
  114. void mergeSort(std::vector<int>& arr, int left, int right) {
  115. if (left < right) {
  116. int middle = left + (right - left) / 2;
  117. mergeSort(arr, left, middle);
  118. mergeSort(arr, middle + 1, right);
  119. merge(arr, left, middle, right);
  120. }
  121. }
  122. void runS() {
  123. // std::random_device rd;
  124. // std::mt19937 gen(rd());
  125. // std::uniform_int_distribution<int> dis(1, 100);
  126. vector<int> nums;
  127. nums.reserve(10);
  128. // for (int i = 0; i < 10; ++i) {
  129. // nums.push_back(dis(gen));
  130. // }
  131. nums.push_back(11);
  132. nums.push_back(6);
  133. nums.push_back(9);
  134. nums.push_back(23);
  135. nums.push_back(6);
  136. nums.push_back(11);
  137. nums.push_back(26);
  138. nums.push_back(40);
  139. nums.push_back(8);
  140. nums.push_back(95);
  141. for (int i: nums) {
  142. cout << i << " ";
  143. }
  144. cout << endl;
  145. shellSort(nums);
  146. for (int i: nums) {
  147. cout << i << " ";
  148. }
  149. }
  150. #endif //LEECODE_C_SHELLSORT_H
备用站点 当前处于降级运行的备用站点,仅供应急访问,数据和功能可能不是最新。