首页 > 编程语言 >排序算法——冒泡排序

排序算法——冒泡排序

时间:2024-11-14 22:47:15浏览次数:3  
标签:temp int 交换 冒泡排序 算法 数组 排序

目录

一、冒泡排序的原理

二、冒泡排序的过程

三、代码实现

总结


一、冒泡排序的原理

冒泡排序是一种简单的排序算法,它通过从左往右依次遍历,比较相邻元素的大小,并根据需要交换它们的位置来排序数据,以升序为例,这个过程类似空中的泡泡,重量大的往下沉,重量小的往上浮,从而得名冒泡排序。

二、冒泡排序的过程

为了更加形象得表达这个过程,我将数组竖起来表示,首先定义一个temp作为中间变量用于交换数据,比如数组是a=[10,5,20,30,15,25],

 然后判断a[0]和a[1]的关系,a[0]>a[1],由于大的要往下“沉”,所以交换10和5的位置,所以引入temp来交换值。

接着再往下比较a[1]和a[2]的大小,因为 a[1]<a[2],所以不用交换,接着往下,比较a[2]和a[3]的大小,仍然不用交换,再比较a[3]和a[4]的大小,a[3]>a[4],所以交换a[3]和a[4]的值。

 最后比较a[4]和a[5]的值,a[4]>a[5],继续交换两者的值

这是第一趟排序,成功把最大的30放到了最下面,然后再回到第一个单元格,进行第二趟排序......

由于每趟排序都可以排好一个位置,所以经过n-1趟就能将数组排序好,并且每趟排序之后下一趟可是少进行一次比较,因为最下面的已经被排序过了,无需再次比较。

三、代码实现

void Bubble(int n, int* a)
{
	int temp;
	for (int i = 1; i <= n - 1; i++)
	{
		for (int j = 0; j < n - i; j++)
		{
			if (a[j] > a[j + 1])
			{
				temp = a[j];
				a[j] = a[j + 1];
				a[j + 1] = temp;
			}
		}
	}
}

总结

这种排序方法的优点是思路简单,便于理解和编写,而且是直接对数组进行操作,节省内存;缺点是循环次数较多(需要排序n-1次),运行速度较慢。可以学习,拓展思路。本节到这里了,不懂的小伙伴可以私信我。

标签:temp,int,交换,冒泡排序,算法,数组,排序
From: https://blog.csdn.net/2401_88004140/article/details/143781648

相关文章

  • 秒懂-----冒泡排序
    排序方法是一种重要的,基本的算法。我相信很多人学习的第一个排序算法就是冒泡排序。可是有很多人(包括作者本人)在开始学冒泡排序时,总是会有这种感觉------明明一听就懂,为何就是写不出代码!!归根结底时没有去深入它。何为冒泡生活中的冒泡请大家想象一口大锅,里面装满了水,现在......
  • C语言:数组(一维数组,二维数组,数组越界,数组作为函数参量,冒泡排序)
    1、一维数组的创建和初始化1.1、数组的创建数组是相同类型元素的集合•数组中可以存放1个或者多个数据•数组中存放的数据,类型是相同的数组的创建方式:元素类型自定义数组名(常量表达式)比如:intarr[10]doublearr[5]chararr[8+5]错误写法:intarr[n];......
  • 代码随想录算法训练营day46| 647. 回文子串 516.最长回文子序列
    学习资料:https://programmercarl.com/0647.回文子串.html#算法公开课动态规划最后一部分:回文字符串子串是从原字符串中连续截取的;子序列可以是从原字符串中不连续提取出元素构成的学习记录:647.回文子串(难构造dp数组,dp数组是从原字符串截取[i,j]范围的片段是否是回文字符串,布尔......
  • 深入浅出学算法044-最大整数
    题目描述设有n个正整数(n≤20),将它们联接成一排,组成一个最大的多位整数。      例如:n=3时,3个整数13,312,343联接成的最大整数为:34331213      又如:n=4时,4个整数7,13,4,246联接成的最大整数为:7424613输入输入分2行第一行是n第2行是n个整数输出连接成的多位数......
  • 深入浅出学算法031-平面分割
    题目描述同一平面内有n(n≤500)条直线,已知其中p(p≥2)条直线相交于同一点,则这n条直线最多能将平面分割成多少个不同的区域?输入两个整数n(n≤500)和p(如果n>=2则2≤p≤n)。输出一个正整数,代表最多分割成的区域数目。样例输入125样例输出73代码走起代码#include<bits/std......
  • ybtoj:贪心算法
    A:点击查看代码#include<bits/stdc++.h>usingnamespacestd;intn,a,b;priority_queue<int>q;intsum=0;intmain(){ scanf("%d%d%d",&n,&a,&b); //cin>>n>>a>>b; for(inti=1;i<=n;i++) { intx; ......
  • Java常见排序算法详解:快速排序、插入排序与冒泡排序
    在程序设计中,排序是最基本的操作之一。Java提供了多种排序算法,今天我们将介绍三种常见的排序方法:快速排序、插入排序和冒泡排序。我们不仅会分析它们的基本原理,还会提供实际的代码实现,帮助大家更好地理解并应用这些排序算法。一、快速排序(QuickSort)快速排序是一种分治法的排......
  • 快速排序和归并排序的比较
    基本原理比较快速排序:基于分治策略。它选择一个基准元素(pivot),通过一趟排序将待排序序列分割成两部分,其中左边部分的元素都小于等于基准元素,右边部分的元素都大于等于基准元素。然后对这两部分分别进行快速排序,递归地重复这个过程,直到整个序列有序。例如,对于序列[4,7,......
  • 代码随想录算法训练营第一天| 704. 二分查找、35.搜索插入位置、27. 移除元素、977.有
    文档讲解:代码随想录视频讲解:代码随想录状态:完成4道题一、数组理论基础数组:连续内存空间,存储类型相同的元素集合,适合读不适合写注意:Python里可以存储不同类型的元素,但刷题时都是按照相同元素去做的相同元素占用存储的空间大小是一样的,下一个元素的位置就确定了数组时间......
  • 代码随想录算法训练营第二天| 209.长度最小的子数组、59. 螺旋矩阵 II
    文档讲解:代码随想录视频讲解:代码随想录状态:完成2道题滑动窗口滑动窗口:两个指针一前一后组成滑动窗口,并计算滑动窗口中的元素的问题适用场景:字符串匹配问题、子数组问题、定长问题滑动窗口模板:如果一个字符进入窗口,应该增加windows计数器;如果一个字符将移除窗口的......