当前位置: 首页 > article >正文

【C语言】_冒泡排序及其优化思路

目录

1. 第一版代码:无忧化版

2. 第二版代码:添加逐趟判断有序的优化版


核心思想:两两相邻的元素进行比较

1. 第一版代码:无忧化版

#include<stdio.h>
void bubble_sort(int* arr, int sz) {
	// 确定趟数: 
	// (对于目标升序的冒泡排序,一趟可实现待排序数中最大数被置于最后)
	// 第0趟结束,待排序数个数:9个,排好序数个数:1个;
	// 第1趟结束:待排序数个数:8个,排好序数个数:2个;
	// 第i趟结束:待排序数个数:sz-1-i个,排好序数个数:i+1个;
	// 对于sz个数,当i=sz-1时,完成所有数的排序,即需排sz-1趟
	int i = 0;
	for (int i = 0; i < sz - 1; i++) {
		// 1趟排序内
		int j = 0;
		// 确定1趟内比较次数:
		// 对于第0趟,待排序数个数:10个,需比较的数的对数:9对
		// 对于第1趟,待排序数个数: 9个,需比较的数的对数:8对
		// 对于第i趟,待排序数个数:sz-i个,需比较的数的对数:sz-1-i对
		for (j = 0; j < sz-1-i; j++) {
			if (arr[j] > arr[j + 1]) {
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
}
void Print(int* arr, int sz) {
	for (int i = 0; i < sz; i++) {
		printf("%d ", *(arr + i));
	}
}
int main() {
	int arr[10] = { 9,8,7,6,5,4,3,2,1,0};
	int sz = sizeof(arr) / sizeof(arr[0]);
	// 调用排序函数(升序)
	bubble_sort(arr,sz);
	// 调用打印函数
	Print(arr, sz);
	return 0;
}

运行结果如下:

2. 第二版代码:添加逐趟判断有序的优化版

第一版代码的测试排序数序列是原本降序,调用冒泡排序实现升序的极端情况;

而当待排序数列不至于极端,即接近目标有序情况时,第一版代码的排序会浪费大量时间与资源;

考虑优化:当某一趟排序过程未发生任何交换时,判定该序列已经有序

具体优化思路为:设置有序标志flag,在每一趟排序中先假设该序列已经有序(即将flag置1)。若在本趟排序中发生交换(即实际上该序列尚未有序),则将flag再次置0。在排序函数体末尾对flag进行判断,若flag==1则表示本趟未发生交换,终止后续无效的判断趟数

代码如下:

#include<stdio.h>
void bubble_sort(int* arr, int sz) {
	// 确定趟数: 
	// (对于目标升序的冒泡排序,一趟可实现待排序数中最大数被置于最后)
	// 第0趟结束,待排序数个数:9个,排好序数个数:1个;
	// 第1趟结束:待排序数个数:8个,排好序数个数:2个;
	// 第i趟结束:待排序数个数:sz-1-i个,排好序数个数:i+1个;
	// 对于sz个数,当i=sz-1时,完成所有数的排序,即需排sz-1趟
	int i = 0;
	for (int i = 0; i < sz - 1; i++) {
		// 1趟排序内
		// 假设该序列已经有序:
		int flag = 1;
		int j = 0;
		// 确定1趟内比较次数:
		// 对于第0趟,待排序数个数:10个,需比较的数的对数:9对
		// 对于第1趟,待排序数个数: 9个,需比较的数的对数:8对
		// 对于第i趟,待排序数个数:sz-i个,需比较的数的对数:sz-1-i对
		for (j = 0; j < sz-1-i; j++) {
			if (arr[j] > arr[j + 1]) {
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
				// 进入循环体发生交换<=>序列非有序,将标志重置为0:
				flag = 0;
			}
		}
		// 本趟未交换,则表示序列已经有序,终止后续趟数
		if (flag == 1) {
			break;
		}
	}
}
void Print(int* arr, int sz) {
	for (int i = 0; i < sz; i++) {
		printf("%d ", *(arr + i));
	}
}
int main() {
	int arr[10] = { 9,8,7,6,5,4,3,2,1,0};
	int sz = sizeof(arr) / sizeof(arr[0]);
	// 调用排序函数(升序)
	bubble_sort(arr,sz);
	// 调用打印函数
	Print(arr, sz);
	return 0;
}

运行结果如下:


http://www.kler.cn/a/472529.html

相关文章:

  • 如何用 ESP32-CAM 做一个实时视频流服务器
  • 【搜索】【推荐】大 PK
  • 汇编实现函数调用
  • 更换WordPress主题的基础知识及注意事项
  • 基于RK3568/RK3588大车360度环视影像主动安全行车辅助系统解决方案,支持ADAS/DMS
  • libaom 源码分析线程结构
  • 用Python实现货运分析地图应用
  • 经典多模态模型CLIP - 直观且详尽的解释
  • onLoad 生命周期函数是否执行取决于跳转的方式和小程序的页面栈管理机制
  • 移动支付安全:五大威胁及防护策略
  • spark functions函数合集(无示例)
  • dockerfile 中 #(nop)
  • 物联网协议:比较MQTT、CoAP和HTTP以实现高效设备通信
  • 【Leetcode 热题 100】33. 搜索旋转排序数组
  • vulnhub靶场-Deathnote(至获取shell)
  • Linux下文件重定向
  • 【OJ刷题】同向双指针问题
  • CSS语言的编程范式
  • 变压器的啸叫、气隙、中心抽头
  • 表格、列表和表单标签
  • JAVA开发学习Day8
  • hive在大数据体系里面起到什么作用
  • CSS 伪类和伪元素:为你的选择器注入更多活力
  • 开源免费GitHub搭建资源分享站
  • NGINX 支持 UDP 协议
  • 【机器学习】农业 4.0 背后的智慧引擎:机器学习助力精准农事决策