排序....

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 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
Cinema KI1 小时前
吃透C++继承:不止是代码复用,更是面向对象设计的底层思维
c++
jianqiang.xue1 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈2 小时前
Python数据结构
数据结构·算法·排序算法
J***79393 小时前
后端在分布式系统中的数据分片
算法·哈希算法
Dream it possible!4 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo4 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon344 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星5 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
Bona Sun5 小时前
单片机手搓掌上游戏机(十四)—pico运行fc模拟器之电路连接
c语言·c++·单片机·游戏机