排序(选择排序 ,冒泡排序,归并排序)

//选择排序 简单排序 不稳定

//如果有n个值进行排序 则需要n-1趟

//每一趟具体是将待排序序列中最小值找到 再将其和待排序序列的第一个值进行交换 (每一趟我们要找到的是最小值的位置 而不是最小值是多少)

void Select_Sort(int arr\[\], int len)

{

for (int i = 0; i < len-1;i++) //趟数

{

int min = i;

for (int j = i + 1; j < len;j++)//控制的是这一趟中对待排序序列值的遍历 从而找到待排序序列最小值所在位置

{

if (arrj < arrmin)

min = j;

}

if (min != i)//判断待排序序列最小值是否与第一个值相等

{

int tmp = arrmin;

arrmin = arri;

arri = tmp;

}

}

}

//冒泡排序 时间复杂度o(n~2) 空间复杂度 O(1)

//如果有n个值进行排序 则需要n-1趟 简单排序 稳定

// 每一趟都从开始位置从左向右遍历 两两比较 如果左边值大于右边值 则交换 (每趟都可以将排序序列中的最大值通过两两比较交换的方式,蠕动到最后)

void Bubble_Sort(int arr\[\], int len)

{

for (int i = 0; i < len - 1; i++) //趟数

{

for (int j = i ; j < len-1-I; j++)//控制的是这一趟中对雨待排序序列从左向右的两两比较取值的过程

{

if (arrj >= arrj + 1)//两两比较时 如果左边值>右边值 交换

{

int tmp = arrj;

arrj = arrj + 1;

arrj + 1 = tmp;

}

}

}

}

//优化 时间复杂度 最坏O(n~2) 最好 O(n)

void Bubble_Sort(int arr\[\], int len)

{

bool tag = true;

for (int i = 0; i < len - 1; i++) //趟数

{

for (int j = i; j < len - 1 - I; j++)//控制的是这一趟中对雨待排序序列从左向右的两两比较取值的过程

{

if (arrj >= arrj + 1)//两两比较时 如果左边值>右边值 交换

{

int tmp = arrj;

arrj = arrj + 1;

arrj + 1 = tmp;

tag = false;

}

}

if (tag)

return;

}

}

//归并排序 分治

//归并排序 两个有序组合并成一个有序组的函数

void Merge(int arr\[\], int left, int mid, int right)

{

//left, mid mid+1, right

int* brr = (int*)malloc(right - left + 1);

if (NULL == brr)

exit(EXIT_FAILURE);

int i = left;

int j = mid + 1;

int k = 0;//指向brr中接收值的格子下标

while (i <= mid && j <= right)

{

if (arri <= arrj)

{

brrk++ = arri++;

//i++;

//k++;

}

else

{

brrk++ = arrj++;

}

}

while (i <= mid)

brrk++ = arri++;

while (j <= right)

brrk++ = arrj++;

for (int w = left; w <= right; w++)

arrw = brrw - left;

}

//归并排序 递归分函数实现

void Divide(int arr\[\], int left, int right)

{

if (left >= right)

{

return; //3 13

}

int mid = (left + right) / 2;

Divide(arr, left, mid);//分好的左边组的范围 left, mid

Divide(arr, mid + 1, right);//分好的右边组的范围 mid+1, right

Merge(arr, left, mid, right);

}

//归并排序 递归实现方法

void Merge_Sort(int arr\[\], int len)

{

//执行分 递归函数

//divide merge

Divide(arr, 0, len - 1);

}

相关推荐
先吃饱再说15 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰18 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术19 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考2 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队2 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法