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进行排序,并传递两个参数给这个函数:数组本身和数组中元素的数量。

相关推荐
xlp666hub2 小时前
Leetcode第七题:用C++解决接雨水问题
c++·leetcode
NE_STOP3 小时前
MyBatis-plus进阶之映射与条件构造器
java
肆忆_4 小时前
实战复盘:手写 C++ 虚拟机的高性能并行 GC (Thread Pool + Work Stealing)
c++
肆忆_4 小时前
虚函数进阶答疑:把上一篇博客评论区里最容易卡住的问题,一次追到底
c++
Seven975 小时前
NIO的零拷贝如何实现高效数据传输?
java
架构师沉默20 小时前
别又牛逼了!AI 写 Java 代码真的行吗?
java·后端·架构
saltymilk20 小时前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
后端AI实验室1 天前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术1 天前
Java 实现企业微信扫码登录
java·企业微信
xlp666hub1 天前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode