排序....

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;

}

相关推荐
UestcXiye1 小时前
《TCP/IP网络编程》学习笔记 | Chapter 3:地址族与数据序列
c++·计算机网络·ip·tcp
好奇龙猫2 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
霁月风2 小时前
设计模式——适配器模式
c++·适配器模式
sp_fyf_20242 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
ChoSeitaku3 小时前
链表交集相关算法题|AB链表公共元素生成链表C|AB链表交集存放于A|连续子序列|相交链表求交点位置(C)
数据结构·考研·链表
偷心编程3 小时前
双向链表专题
数据结构
香菜大丸3 小时前
链表的归并排序
数据结构·算法·链表
jrrz08283 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time3 小时前
golang学习2
算法
咖啡里的茶i3 小时前
Vehicle友元Date多态Sedan和Truck
c++