C/C++ 冒泡排序

第一题:排序 4,3,5,2,1从小到大
cpp 复制代码
#include <bits/stdc++.h>   //冒泡排序 
using namespace std; 
int main()
{
	
	int a[5] = {4,3,5,2,1};
	int i,j,tmp;
	for(i=0;i<5;i++)
	{
		for(j=0;j<5-i;j++)
		{
			if(a[j]>a[j+1])
			{
				tmp=a[j];
				a[j]=a[j+1];
				a[j+1]=tmp;
			}
		}
	}
	for(i=0;i<5;i++)
	{
		cout<<" "<<a[i];
	}
	return 0; 
 } 
重要知识点:

(1)交换数值:

cpp 复制代码
			if(a[j]>a[j+1])
			{
				tmp=a[j];
				a[j]=a[j+1];
				a[j+1]=tmp;}

(2) 两个for循环冒泡;

第一题的高阶写法(调用函数):
代码:
cpp 复制代码
#include <bits/stdc++.h>   //冒泡排序 
using namespace std; 
void bubble_sort(int *a,int n)
{
		for(int i=0;i<n-1;i++)
	{
		for(int j=0;j<n-i-1;j++)
		{
			if(a[j]>a[j+1])
			{
			    int	tmp=a[j];
				a[j]=a[j+1];
				a[j+1]=tmp;
			}
		}
	}
}
void printf_a(int *a,int n)
{
		for(int i=0;i<n;i++)
	{
		cout<<" "<<a[i];
	}
}
int main()
{
	
	int a[5] = {4,3,5,2,1};
    bubble_sort(a,sizeof(a)/sizeof(int));
    printf_a(a,sizeof(a)/sizeof(int));
	return 0; 
 } 
重要知识点:

(1)求数组个数:

cpp 复制代码
sizeof(a)/sizeof(int)

(2)调用函数解释(Al)

cpp 复制代码
bubble_sort(a,sizeof(a)/sizeof(int));

这段代码是C语言中的一部分,用于调用一个名为bubble_sort的函数来对一个整数数组a进行冒泡排序。

具体解释如下:

bubble_sort: 这是函数的名称,表示这是一个冒泡排序的函数。

a: 这是传递给函数的数组。

sizeof(a): 这是计算数组a的字节大小。

sizeof(int): 这是计算整数的大小。

sizeof(a)/sizeof(int): 通过这个表达式,我们得到了数组a中元素的数量。

所以,bubble_sort(a,sizeof(a)/sizeof(int));的意思是:调用bubble_sort函数来对数组a进行排序,并传递两个参数给这个函数:数组本身和数组中元素的数量。

相关推荐
豐儀麟阁贵1 分钟前
2.3变量与常量
java·开发语言
兮动人1 小时前
Eureka注册中心通用写法和配置
java·云原生·eureka
什么半岛铁盒1 小时前
C++11 多线程与并发编程
c语言·开发语言·c++
爱编程的小白L3 小时前
基于springboot志愿服务管理系统设计与实现(附源码)
java·spring boot·后端
Mr_WangAndy4 小时前
C++设计模式_结构型模式_组合模式Composite(树形模式)
c++·设计模式·组合模式
Kiri霧5 小时前
Linux下的Rust 与 C 的互操作性解析
c语言·开发语言·rust
聪明的笨猪猪5 小时前
Java Redis “持久化”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
聪明的笨猪猪6 小时前
Java Redis “核心基础”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
迎風吹頭髮6 小时前
UNIX下C语言编程与实践62-UNIX UDP 编程:socket、bind、sendto、recvfrom 函数的使用
c语言·单片机·unix
奋斗的小monkey8 小时前
Spring Boot 3.x核心特性与性能优化实战
java·spring boot·微服务·性能优化·响应式编程