排序....

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;

}

相关推荐
安全二次方security²2 分钟前
CUDA C++编程指南(7.31&32&33&34)——C++语言扩展之性能分析计数器函数和断言、陷阱、断点函数
c++·人工智能·nvidia·cuda·断点·断言·性能分析计数器函数
知无不研2 分钟前
选择排序算法
数据结构·算法·排序算法·选择排序
好学且牛逼的马2 分钟前
【Hot100|21-LeetCode 160. 相交链表】
算法·leetcode
爱学习的阿磊3 分钟前
C++中的策略模式应用
开发语言·c++·算法
郝学胜-神的一滴4 分钟前
Python中的bisect模块:优雅处理有序序列的艺术
开发语言·数据结构·python·程序人生·算法
筵陌5 分钟前
算法:位运算
算法
L_090710 分钟前
【Linux】进程状态
linux·开发语言·c++
Christo311 分钟前
TKDE-2026《Efficient Co-Clustering via Bipartite Graph Factorization》
人工智能·算法·机器学习·数据挖掘
NaCl鱼呜啦啦11 分钟前
0126-0201编程心得
c++
2401_8384725112 分钟前
C++异常处理最佳实践
开发语言·c++·算法