冒泡排序算法,排序原理(最详细)

今天刷题时,遇见一道将数组中元素排序的题。有些忘了,就回顾复习一下
冒泡排序:是一种算法,每趟将相邻的两个数比较,把一系列的数据按照一定的顺序进行显示(从小到大或者从大到小)

算法思想

  1. 一共需要比较的趟数(数组长度 - 1),用外层for循环
  2. 第n趟需要交换的次数(数组长度-n),用内层for循环

以C程序为例进行演示

#include<stdio.h>
int main(void)
{
	int temp;				//temp用于交换相邻元素的值
	int i,j;
	int a[]={5,4,3,2,1};
	for(i=1;i<5;i++)		//外层计数变量,i
	{
		for(j=0;j<5-i;j++)	//内层计数变量,j
		{
			if(a[j]>a[j+1])
			{
				temp = a[j];
				a[j] = a[j+1];
				a[j+1] = temp;
			}
		}
	}
	for(i = 0;i<5;i++)		//将数组中的元素循环输出即可,也可以使用其他的计数变量
	{
		printf("%d ",a[i]);
	}
	printf("\n");
	return 0;
}

外层循环变量尽量从1开始计数,它只表示要走的趟数
内层变量从0开始计数,它才涉及到每个元素,要进行交换

Computational Results

在这里插入图片描述

详细排序原理示意图可点击下面链接
https://blog.csdn.net/weixin_41457674/article/details/98517098

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值