排序....

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;

}

相关推荐
电科一班林耿超1 分钟前
第 14 课:动态规划(DP)—— 算法思想的巅峰,面试的终极分水岭
数据结构·算法·动态规划
菜菜的顾清寒1 分钟前
C++面试题自用-持续更新
开发语言·c++
lihao lihao5 分钟前
Linux文件与fd
java·linux·算法
Navigator_Z8 分钟前
LeetCode //C - 1026. Maximum Difference Between Node and Ancestor
c语言·算法·leetcode
t***5448 分钟前
如何在 Dev-C++ 中使用 Clang 调试
开发语言·c++
c++之路9 分钟前
C++ 重载函数、运算符重载、抽象类(接口)
开发语言·c++
We་ct17 分钟前
LeetCode 63. 不同路径 II:动态规划解题详解
前端·算法·leetcode·typescript·动态规划
汉克老师17 分钟前
GESP2023年6月认证C++三级( 第三部分编程题(1、春游))
c++·数组·计数·gesp三级·gesp3级
aq553560023 分钟前
Laravel8.x新特性全解析
c++·elasticsearch·mfc
如君愿25 分钟前
考研复习 Day 20 | 数据结构与算法--查找
数据结构·考研·算法·记录考研