排序....

1.直接插入排序

1.1将数组分为有序和无序部分 无序部分插入到有序部分4

#include<iostream>

using namespace std;

void InsertSort(int a[], int n) {

int tmp;

int j;

for (int i = 1; i < n; i++) {

if (a[i] < a[i - 1]) {

tmp = a[i];

for ( j = i - 1; j >= 0 && tmp < a[j]; j--) {

a[j + 1] = a[j];

}

a[j + 1] = tmp;

}

}

}

void Print_a(int a[], int n) {

for (int i = 0; i < n; i++) {

cout << a[i] << " ";

}

}

int main() {

int a[10] = { 1,9,2,8,3,7,4,6,5,10 };

int n = sizeof(a) / sizeof(a[0]);

InsertSort(a, n);

Print_a(a, n);

return 0;

}

希尔排序

#include<iostream>

using namespace std;

void ShellSort(int a[], int n) {

int gap = n;

while (gap > 1) {

gap = gap / 3 + 1;

int i;

for (int i = 0; i < n -gap; i++) {

int end = i;

int tmp = a[end + gap];

while (end >= 0) {

if (a[end] > tmp) {

a[end + gap] = a[end];

end -= gap;

}

else break;

}

a[end + gap] = tmp;

}

}

}

void print_a(int a[], int n) {

for (int i = 0; i < n; i++) {

cout << a[i] << " ";

}

}

int main() {

int a[] = { 1,9,2,8,3,7,4,6,5,10 };

int n = sizeof(a) / sizeof(a[0]);

ShellSort(a, n);

print_a(a, n);

return 0;

}

简单选择排序

#include<iostream>

using namespace std;

void SelectSort(int a[], int n) {

for (int i = 0; i < n - 1; i++) {

int Min = i;

for (int j = i + 1; j < n; j++) {

if (a[j] < a[Min]) {

Min = j;

}

}

if (Min != i) {

swap(a[i], a[Min]);

}

}

}

void print_a(int a[], int n) {

for (int i = 0; i < n; i++) {

cout << a[i] << " ";

}

}

int main() {

int a[] = { 1,9,2,8,3,7,4,6,5,10 };

int n = sizeof(a) / sizeof(a[0]);

SelectSort(a, n);

print_a(a, n);

return 0;

}

相关推荐
@老蝴3 小时前
C语言 — 通讯录模拟实现
c语言·开发语言·算法
L-ololois3 小时前
【AI】模型vs算法(以自动驾驶为例)
人工智能·算法·自动驾驶
安全系统学习5 小时前
网络安全之RCE简单分析
开发语言·python·算法·安全·web安全
byte轻骑兵6 小时前
【C++特殊工具与技术】优化内存分配(四):定位new表达式、类特定的new、delete表达式
开发语言·c++
GEEK零零七6 小时前
Leetcode 3299. 连续子序列的和
算法·leetcode·动态规划
飞飞是甜咖啡6 小时前
【机器学习】Teacher-Student框架
人工智能·算法·机器学习
广州正荣7 小时前
成绩管理革新者:C++驱动的智能数据处理平台
c++·人工智能·科技
蒟蒻小袁7 小时前
力扣面试150题--单词接龙
算法·leetcode·面试
90wunch7 小时前
对象回调初步研究
c++·windows·安全
Se_ren_di_pity7 小时前
C++ STL容器汇总
开发语言·c++