酷代码 AI
菜单
服务商

C++ 实现希尔排序:将随机序列排序的超详细代码解析

以下是一个简单的希尔排序函数 `shellsort` 的实现示例: ```cpp #include <iostream> using namespace std; #include <stdlib.h> #include <time.h> const int n = 10; const int min = 10; const int max = 99; int getrand(int min, int max) { return (rand() % (max - min + 1) + min); } void set(int r[], int n) { int i; for (i = 0; i < n; i++) r[i] = getrand(min, max); } void show(int r[], int n) { int i; for (i = 0; i < n; i++) cout << r[i] << " "; cout << endl; } void shellsort(int r[], int n) { int gap, i, j, temp; for (gap = n / 2; gap > 0; gap /= 2) { for (i = gap; i < n; i++) { temp = r[i]; for (j = i; j >= gap && r[j - gap] > temp; j -= gap) r[j] = r[j - gap]; r[j] = temp; } } } int main() { srand(time(0)); int a[n]; set(a, n); cout << "原序列: "; show(a, n); shellsort(a, n); cout << "新序列: "; show(a, n); return 0; } ``` 希尔排序是一种插入排序的改进算法,通过选择不同的步长逐步对数组进行排序。 ######[AI写代码神器 | 407点数解答 | 2024-10-31 11:04:08]

相关提问
本站限时免费提问中
实用工具查看更多
Linux在线手册 [开发类]
Jquery在线手册 [开发类]
今日油价 [生活类]
图片互转base64 [开发类]
时间转换器 [开发类]