数据结构五大排序算法之冒泡排序

数据结构五大排序算法之冒泡排序



前言:

一、冒泡排序是什么?

1.1百度百科和我的理解:

它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。走访元素的工作是重复地进行,直到没有相邻元素需要交换,也就是说该元素列已经排序完成。
下面的图是我的理解,但是csdn我不知道怎么改颜色就用图片放了,要突出重点

冒泡排序:
在这里插入图片描述

1.2冒泡思路:

两个循环控制,A控制轮次,B控制比较,
每一轮的B都从第一个开始循环比较,但是A每循环一轮,B就要少循环一次,B循环一轮,会多一个有序

思路:注意我少些了一行,第二轮比到12就可以了,比完第二轮98,已经到最后了,下一轮比到倒数第三个就行了
在这里插入图片描述

下面的动态图只表示了第一次,而且前面三个的比较没有显示出来

1.3动图演示:

在这里插入图片描述


大家只看我的冒泡函数就行,都放出来是方便一些好兄弟直接cv编程;

1.4完整代码:

#include <stdio.h>
#include <stdlib.h>

void maopao(int* arr)
{
	int i=0;//定义两个变量,等会用来控制循环
    int j=0;
    int temp;
    for(i=0;i<5;i++)//用for循环,表示有5轮循环,控制循环的轮数
    {
		for(j=1;j<5-i-1;j++)//用for循环,嵌套在轮数里面,表示每一轮要比较的次数
        {					//这个地方需要注意的是,轮数每循环一次,次数就要减少一次,因为循环一轮,最后就多一个数就有序了
							//循环两轮,最后两个数就有序,循环几轮,最后就有几个有序,所以次数要减
			if(arr[j]>arr[j+1])//用if判断,如果前面的比后面的大,那么我们就交换他们的值
            {	
				temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
    
}
int main()
{
	int arr[5]={5,658,98,45,12};
    int size=sizeof(arr)/sizeof(arr[0]);//sizeof是计算大小,数组大小除以一个节点,那就是有多少个元素
    maopao(arr);//数组名就是地址,我们直接拿数组名当指针用,当实参传递,数组名=数组首元素地址=数组地址
    int i=0;
    for(i=0;i<5;i++)
    {
		printf("%d ",arr[i]);
    }
    printf("PZK666\n");
    system("pause");
	return 0;
}


---------------------------------------------------------------------------------------------------------------------------------------------------------------

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值