This commit is contained in:
2025-09-15 21:12:04 +08:00
commit 3f58f483ff
144 changed files with 5298 additions and 0 deletions

171
else/sorts.h Normal file
View File

@@ -0,0 +1,171 @@
//
// Created by 李洋 on 2023/10/19.
//
#ifndef LEECODE_C_SHELLSORT_H
#define LEECODE_C_SHELLSORT_H
#include <vector>
#include <random>
#include <iostream>
using namespace std;
void shellSort(vector<int> &arr) {
int n = arr.size();
// 选择增量序列,可以根据需要选择不同的序列
for (int gap = n / 2; gap > 0; gap /= 2) {
// 使用插入排序对每个子数组进行排序
for (int i = gap; i < n; ++i) {
int temp = arr[i];
int j = i;
while (j >= gap && arr[j - gap] > temp) {
arr[j] = arr[j - gap];
j -= gap;
}
arr[j] = temp;
}
}
}
// 快速排序 - start
int partition(vector<int> &arr,int left,int right){
int sign = arr[left];
while(left < right){
while(left < right && sign <= arr[right]){
right--;
}
swap(arr[left],arr[right]);
while(left < right && arr[left] <= sign){
left++;
}
swap(arr[left],arr[right]);
}
return left;
}
void splits(vector<int> &arr,int left,int right){
if (left < right)
{
int norm = partition(arr,left,right);
splits(arr,left,norm - 1);
splits(arr,norm + 1,right);
}
}
void quickSort(vector<int> &arr) {
splits(arr, 0, arr.size() - 1);
}
// 快速排序 - end
// 堆排序 - start small -> large
void maxHeapify(vector<int> &arr, int n, int i) {
int largest = i;
int left = i * 2 + 1;
int right = i * 2 + 2;
if (left < n && arr[left] > arr[largest]) {
largest = left;
}
if (right < n && arr[right] > arr[largest]) {
largest = right;
}
if (largest != i) {
swap(arr[i], arr[largest]);
maxHeapify(arr, n, largest);
}
}
void heapSort(vector<int> &arr) {
auto n = arr.size();
for (int i = n / 2 - 1; i >= 0; --i) {
maxHeapify(arr, n, i);
}
for (int i = n - 1; i > 0; i--) {
swap(arr[0], arr[i]);
maxHeapify(arr, i, 0);
}
}
// 堆排序 - end small -> large
// 归并排序
void merge(std::vector<int>& arr, int left, int middle, int right) {
int n1 = middle - left + 1;
int n2 = right - middle;
std::vector<int> leftArr(n1);
std::vector<int> rightArr(n2);
for (int i = 0; i < n1; i++) {
leftArr[i] = arr[left + i];
}
for (int i = 0; i < n2; i++) {
rightArr[i] = arr[middle + 1 + i];
}
int i = 0, j = 0, k = left;
while (i < n1 && j < n2) {
if (leftArr[i] <= rightArr[j]) {
arr[k] = leftArr[i];
i++;
} else {
arr[k] = rightArr[j];
j++;
}
k++;
}
while (i < n1) {
arr[k] = leftArr[i];
i++;
k++;
}
while (j < n2) {
arr[k] = rightArr[j];
j++;
k++;
}
}
void mergeSort(std::vector<int>& arr, int left, int right) {
if (left < right) {
int middle = left + (right - left) / 2;
mergeSort(arr, left, middle);
mergeSort(arr, middle + 1, right);
merge(arr, left, middle, right);
}
}
void runS() {
// std::random_device rd;
// std::mt19937 gen(rd());
// std::uniform_int_distribution<int> dis(1, 100);
vector<int> nums;
nums.reserve(10);
// for (int i = 0; i < 10; ++i) {
// nums.push_back(dis(gen));
// }
nums.push_back(11);
nums.push_back(6);
nums.push_back(9);
nums.push_back(23);
nums.push_back(6);
nums.push_back(11);
nums.push_back(26);
nums.push_back(40);
nums.push_back(8);
nums.push_back(95);
for (int i: nums) {
cout << i << " ";
}
cout << endl;
shellSort(nums);
for (int i: nums) {
cout << i << " ";
}
}
#endif //LEECODE_C_SHELLSORT_H