5.C_Demo_排序

news2024/12/23 19:14:55

冒泡排序法

原理:

依次比较相邻的两个元素,如果顺序错误就交换。

思路:

这种方法,显然需要很多轮才能完成,每一轮只能排序一个最大值或最小值(第一层for),将全部的数据排序完成,需要很多轮(第二层for)。

对于第一层for,就是遍历数组,然后比较大小,进行交换。有两个注意点:

  • 效率:第一次排序完成之后,末尾就已经是最值了,下一次可以不再比较末尾这个数字。
  • 越界:比如数组大小为5,要比较的实际是a[i]与a[i+1],因此i+1要小于5,不能越界

对于第二层for,就是考虑需要比较多少次。有两个注意点:

  • 次数:有5个数,找出4个最值就可以进行排序了,而不是需要找5次。
  • 效率:当第一层for没有进行排序时,代表这个数组已经排序好了,这时可以直接break。

代码接口说明如下:

1、void BubbleSortArray(char* array,int size,char mode);

功能:使用冒泡排序法进行排序

array:数组首地址

size:数组大小

mode:排序模式,' U '代表升序排序,' D '代表降序排序

2、void Print_Array(char* array,int size)

打印调试代码

具体代码实现如下:

#include <stdio.h>

void BubbleSortArray(char* array,int size,char mode){
	
	int i,j;
	char SortFinishFlag = 1;
	
    if(array == NULL){
		printf("err:array is NULL\n");
        return;
	}

	//1.找到size-1个最大/小值,即可进行排序 
	for(j=0;j<size-1;j++){
		
		//2.比到上一个排到的末尾即可 
		for(i=0;i<size-1-j;i++){
			
			switch(mode){
				case 'U'://升序排序,小数在低位 
					if(array[i]>array[i+1]){
						array[i]   = array[i]^array[i+1];
						array[i+1] = array[i]^array[i+1];
						array[i]   = array[i]^array[i+1];
						SortFinishFlag = 0;
					}	
					break;
				case 'D'://降序排序,大数在低位
					if(array[i]<array[i+1]){
						array[i]   = array[i]^array[i+1];
						array[i+1] = array[i]^array[i+1];
						array[i]   = array[i]^array[i+1];
						SortFinishFlag = 0;
					} 
					break;
				default:
					printf("mode err\n");
					return;
			}
		}
		
		printf("Debug:MaxLoopNum = %d,NowLoopNum = %d\n",size-1,j);
		//数据无交换,提前退出 
		if(1 == SortFinishFlag){
				break;	
		}else{
			SortFinishFlag = 1;		
		} 	
	}	
}
/* 打印数组 */ 
void Print_Array(char* array,int size){
	
	int i;
	
	for(i=0;i<size;i++){
		printf("%d ",array[i]);
	}
}

int main(){
	
	char a[]={1,2,3,4,5};
	
	BubbleSortArray(a,sizeof(a)/sizeof(char),'U');
	Print_Array(a,sizeof(a)/sizeof(char));
	
	return 0;
} 

简单排序法

原理:

始终用未排序的第一个进行比较,依次与后面的值进行比较,如果顺序错误就交换。

代码接口说明如下:

1、void SimpleSelectSortArray(char* array,int size,char mode);

功能:使用冒泡排序法进行排序

array:数组首地址

size:数组大小

mode:排序模式,' U '代表升序排序,' D '代表降序排序

2、void Print_Array(char* array,int size)

打印调试代码

具体代码实现如下:

#include <stdio.h>

void SimpleSelectSortArray(char* array,int size,char mode){
	
	int i,j;
	char SortFinishFlag = 1;
	
	if(array == NULL){
		printf("err:array is NULL\n");
		return;
	}
	
	for(i=0;i<size-1;i++){
		
		for(j=i+1;j<size;j++){
			switch(mode){
				case 'U'://升序,小数放低位 
					if(array[i]>array[j]){
						array[i] = array[i] ^ array[j];
						array[j] = array[i] ^ array[j];
						array[i] = array[i] ^ array[j];
						SortFinishFlag = 0;
					} 
					break;
				case 'D'://降序,大数放低位
					if(array[i]<array[j]){
						array[i] = array[i] ^ array[j];
						array[j] = array[i] ^ array[j];
						array[i] = array[i] ^ array[j];
						SortFinishFlag = 0;
					}
					break;
				default:
					printf("mode err"); 
			}
			
		}
		printf("Debug:MaxLoopNum = %d,NowLoopNum = %d\n",size-1,i);
		//数据无交换,提前退出 
		if(1 == SortFinishFlag){
			break;	
		}else{
			SortFinishFlag = 1;		
		} 		
	}
}
/* 打印数组 */ 
void Print_Array(char* array,int size){
	
	int i;
	
	for(i=0;i<size;i++){
		printf("%d ",array[i]);
	}
}
int main(){
	
	char a[]={1,2,3,4,5,6,7,8,9};
	
	SimpleSelectSortArray(a,sizeof(a)/sizeof(char),'U');
	Print_Array(a,sizeof(a)/sizeof(char));
	
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1974977.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第三期书生大模型实战营之书生大模型全链路开源开放体系

一. Introduction 大模型是发展通用人工智能的重要途经 二. 开源历程以及InternLM2 2024年1月17日 InternLM2 2开源 三. 书生浦语2.0的主要亮点 3.1 超长上下文 3.2 综合性能全面提升 3.3 优秀的对话和创作体验 3.4 工具调用能力整体升级 3.5 突出的数理能力和实用的…

Among Us 私服的制作之路

文章目录 Among Us 私服的制作之路这游戏通常包括以下核心元素&#xff1a;角色设定&#xff1a;游戏机制&#xff1a;游戏界面&#xff1a; 第四步&#xff1a;添加社交特性第五&#xff1a;测试与优化方面 十分基础的框架(Web)注意事项 Among Us 私服的制作之路 作者正在准备…

嵌入式:简单的UI框架

1&#xff1a;UI框架简介 除了服务框架外&#xff0c;我们还需要对外显示UI&#xff0c;所以我们就需要一个UI的框架&#xff0c;跟服务框架一样&#xff0c;不用这个UI框架我们也是可以实现&#xff0c;但是这样每个人写的UI都会有差异&#xff0c;需要的事件&#xff0c;数据…

牛客JS题(二十)判断斐波那契数组

注释很详细&#xff0c;直接上代码 涉及知识点&#xff1a; 循环判断斐波那契数列组递归判断斐波那契数列组合法性判断 题干&#xff1a; 我的答案 <!DOCTYPE html> <html><head><meta charset"utf-8" /></head><body><scrip…

嵌入式数据库 sqlite3

数据库文件与普通文件区别: 1.普通文件对数据管理(增删改查)效率低 2.数据库对数据管理效率高,使用方便 常用数据库: 1.关系型数据库 将复杂的数据结构简化为二维表格形式 大型:Oracle、DB2 中型:MySql、SQLServer 小型:Sqlite …

c# .net core项目角色授权机制

前言 角色授权机制是确保应用程序安全性的重要组成部分,它允许开发者根据用户的角色来限制对应用程序中不同资源的访问。 基本概念: 角色授权基于用户角色的访问控制,即根据用户所属的角色来决定其能够访问的资源或执行的操作。在.NET Core中,这通常与身份认证(Authent…

怎么配置一个axios来拦截前后端请求

首先创建一个axios.js文件 导入我们所需要的依赖 import axios from "axios"; import Element from element-ui import router from "./router"; 设置请求头和它的类型和地址 注意先注释这个url,还没有解决跨域问题,不然会出现跨域 // axios.defaults.…

Python Sklearn库SVM算法应用

SVM 是一种有监督学习分类算法&#xff0c;输入值为样本特征值向量和其对应的类别标签&#xff0c;输出具有预测分类功能的模型&#xff0c;当给该模型喂入特征值时&#xff0c;该模型可以它对应的类别标签&#xff0c;从而实现分类。 Sklearn库SVM算法 下面我看一下 Python …

CSS学习 - 选择器

基础选择器 ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 类型选择器&…

牛逼,两百行Python代码带你打造一款《天天酷跑》游戏!(附源码)

《天天酷跑》是一款广受欢迎的跑酷类手机游戏&#xff0c;玩家需要控制角色在赛道上奔跑&#xff0c;躲避障碍物&#xff0c;收集金币和道具&#xff0c;以获取高分。虽然完全复现这款游戏的复杂度和图形效果在简单的Python环境中难以实现&#xff08;特别是游戏图形和动画&…

市电220V

概念 市电 220V 是指在中国及许多其他国家使用的标准交流电压,该值是电压的有效值(RMS值,Root Mean Square)。有效值是交流电压或电流的一个测量方式,它表示在一个周期内,交流电的平方平均值等于直流电压(或电流)的值。 有效值在交流电中具有特殊意义,因为交流电的瞬…

华大基因守护新生健康,基因检测助力新生儿疾病筛查

此前&#xff0c;《中国出生缺陷防治报告》预估我国出生缺陷发生率在5.6%左右&#xff0c;无创产前基因检测技术&#xff08;NIPT&#xff09;等先进产前筛查手段&#xff0c;在我国历经十多年的发展历史&#xff0c;华大基因作为行业引领者&#xff0c;深耕基因检测领域&#…

JavaEE 初阶(11)——多线程9之“阻塞队列”

目录 一. 什么是“阻塞队列” 二. 生产者消费者模型 2.1 概念 2.2 组件 2.3 实际应用 2.4 优点 a. 实现“解耦合” b. 流量控制——“削峰填谷” 2.5 代价 a. 更多的机器 b. 通信时间延长 三. 阻塞队列的实现 3.1 简述 3.2 ArrayBlockingQueue的使用 3.3 实现…

数据建模标准-基于事实建模

前情提要 数据模型定义 DAMA数据治理体系中将数据模型定义为一种文档形式&#xff0c;数据模型是用来将数据需求从业务传递到IT,以及在IT内部从分析师、建模师和架构师到数据库设计人员和开发人员的主要媒介&#xff1b; 作用 记录数据需求和建模过程中产生的数据定义&…

dctcp 比 reno,cubic 好在哪

dctcp 相比标准 aimd 如 reno&#xff0c;cubic 到底好在哪&#xff0c;理论上讲 dctcp 本质上也是 aimd 算法&#xff0c;但它的 cwnd 根据 mark rate 来实时缩放&#xff0c;而标准 reno/cubic 则一致缩放 β 0.5(reno) or β 0.3(cubic)&#xff0c;直观上看 dctcp 是连续…

PostgreSQL数据库内核(一):增加系统表pg_test_catalog

目录 编译环境准备 gdb调试 CLion配置 增加系统表pg_test_catalog 编译环境准备 使用PostgreSQL14.5源码版本编译&#xff0c;操作系统CentOS&#xff0c;本地windos系统CLion代码工具&#xff0c;首先下载pg源码&#xff0c;上传CentOS系统&#xff1a; more /etc/os-rel…

要 set 还是 map? 我全要

引子&#xff1a; 时隔多日&#xff0c;我又回来啦&#xff0c;接上回&#xff0c;我们讲到set的一小部分&#xff0c;我们今天来讲详细讲set与map&#xff0c;满满干货启动&#xff01;根据应用场景的不同&#xff0c;STL总共实现了两种不同结构的管理式容器&#xff1a;树型…

[240803] Prompt Fuzzer 新版本发布 | Windows 会在更新时进行时间调整以减少碳排放

目录 Prompt Fuzzer 新版本发布&#xff1a;更强大、更灵活的 GenAI 应用安全评估工具Windows 会在更新时进行时间调整以减少碳排放 Prompt Fuzzer 新版本发布&#xff1a;更强大、更灵活的 GenAI 应用安全评估工具 Prompt Security 发布了新版 Prompt Fuzzer&#xff0c;这是…

CSS+js:顶部导航栏背景滚动渐变、顶部背景滚动渐变

一、效果图 图1 图2 图3 二、gradual.html代码 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>顶部导航栏渐变和顶部背景渐变</title></head><body><div class"content-root" id&quo…

Linux PSCI框架

Linux PSCI框架 概述 参考链接&#xff1a; 简单讲解Linux PSCI框架-Linxu内核栈 概述 PSCI &#xff08;Power State Coordination Interface&#xff09; 是ARM定义的电源管理接口规范&#xff0c;由firm来实现。Linux系统通过smc/hvc指令&#xff08;设备树可查看是那种&a…