首页 > 编程语言 >算法学习之冒泡排序【C语言】

算法学习之冒泡排序【C语言】

时间:2023-04-09 12:31:25浏览次数:42  
标签:数字 int len C语言 ++ 算法 冒泡排序 排序

冒泡排序

排序规则

冒泡排序的规则是相邻的两个数字依次比较,如果前面的数字比后面的数字大,则交换它们的位置,否则保持不变,直到遍历完所有的数字。这个过程会不断地进行,直到所有的数字都按照从小到大的顺序排列好。

双层循环

在冒泡排序的算法中,需要使用两层循环来实现排序功能。

for (int i = 0; i < len - 1; i++)

外层循环是控制排序的次数,每排一次可以得出一个最大的数,最小的那个不用再排,因此需要排 len-1 次,即 i < len-1。

for (int j = 0; j < len - 1 - i; j++)

内层循环是比较数字的大小,已经排好序的数字不需要再比较,所以需要排除已经排好序的数字,即 j < len-1-i。

交换数据

在冒泡排序的过程中,需要交换两个数字的位置。这个过程可以使用一个新的变量来实现。

int t = a[j];
a[j] = a[j + 1];
a[j + 1] = t;
输出结果

排序完成后,需要将排序好的数字按照从小到大的顺序输出。可以使用循环来实现。

for (int i = 0; i < len; i++)
{
    printf("%d ", a[i]);
}
完整代码

以下是完整的冒泡排序的代码:

#include <stdio.h>

int main()
{
    int a[5] = {5, 3, 2, 1, 4};
    int len = sizeof(a) / sizeof(a[0]);

    for (int i = 0; i < len - 1; i++)
    {
        for (int j = 0; j < len - 1 - i; j++)
        {
            if (a[j] > a[j + 1])
            {
                int t = a[j];
                a[j] = a[j + 1];
                a[j + 1] = t;
            }
        }
    }

    for (int i = 0; i < len; i++)
    {
        printf("%d ", a[i]);
    }

    return 0;
}
总结

冒泡排序的基本原理是相邻的两个数字依次比较,如果前面的数字比后面的数字大,则交换它们的位置,否则保持不变,直到遍历完所有的数字。该算法需要使用双层循环来实现排序功能,外层循环控制排序的次数,内层循环则负责比较数字的大小。在排序的过程中需要交换两个数字的位置,可以使用一个新的变量来实现。最后,排序完成后需要将排序好的数字按照从小到大的顺序输出。

写在最后

为了便于理解,笔者提供的代码示例只能用于固定长度的数组,而不能处理动态长度的数组。为了使代码更加灵活,可以将冒泡排序封装成函数并传入数组和长度作为参数,这样可以在需要排序的时候直接调用该函数。 (如有错误敬请指正,感谢您的观看!)

标签:数字,int,len,C语言,++,算法,冒泡排序,排序
From: https://blog.51cto.com/u_16060410/6178753

相关文章

  • C语言本地变量的规则
    以以下一段代码为例:1#include<stdio.h>2//以下代码是否能交换两个变量的值?3voidswap(inta,intb);45intmain()6{7inta=5;8intb=6;910swap(a,b);1112printf("%d,%d",a,b);1314return0;15}16......
  • 算法-递归三(树形结构)
    publicclassSolution{publicIList<IList<int>>Permute(int[]nums){varrtItem=newList<int>();varvisited=newDictionary<int,bool>();IList<IList<int>>rt=newList<IList<int&......
  • 基于TiDB+Flink实现的滑动窗口实时累计指标算法
    作者:Jellybean前言在不少的支付分析场景里,大部分累计值指标可以通过T+n的方式计算得到。随着行业大环境由增量市场转为存量市场,产品的运营要求更加精细化、更快速反应,这对各项数据指标的实时性要求已经越来越高。产品如果能实时把握应用的整体运行情况或特征用户的状态,就可......
  • 算法学习之选择排序【C语言】
    选择排序排序规则选择排序是一种简单直观的排序算法,其基本思想是每次从待排序的数据元素中选出最小(或最大)的一个元素,存放到序列的起始位置,直到全部元素排序完成。具体步骤如下:1.从第一个数开始,与其后的数一一比较,如后小前大,则交换,依次比较直至最后一组数。2.通过上述步骤,得到参加循......
  • ssh服务支持弱加密算法
    详情描述:远程SSH服务器配置为使用arcfour流密码或无任何密码。RFC4253不建议使用arcfour弱算法。https://tools.ietf.org/html/rfc4253#section-6.3解决方案:解决方法:*在SSH会话中仅使用CTR模式加密算法,如AES-CTR。https://tools.ietf.org/html/rfc4253#section-6.3方案......
  • C语言
    目录1.数据类型:2.数据运算:3.基本语句:1.数据类型:2.数据运算:3.基本语句:本篇随笔为记录学习所用,内容大多来源于网络,如有侵权,请联系博主。......
  • C语言字符串的使用
    做题常常遇到和字符串相关的,发现自己对《字符串》和《字符数组》有误会,因为他们的声明太像了,我会搞混。于是我在DevC++上尝试了9种不同的声明方式,想看看什么时候才算是有效的字符串声明,都是我当前水平可能遇到的。#include<stdio.h>#include<string.h>/* 解释: 字符串和字符......
  • 基于蛙跳算法的最优值计算matlab仿真
    1.算法描述            蛙跳算法是基于种群进化的元启发式算法之一,通过模拟自然界中青蛙觅食过程中种群所体现出的交流与合作行为,以实现对问题的求解。在一片湿地中,分布着一群青蛙,每只青蛙有自己的想法,每只青蛙的想法则被定义为一个解。每只青蛙找到食物时,都会......
  • C4.5分类树算法介绍
    为什么C4.5会出现?因为ID3算法节点的分支越多,信息增益也就越大,这会出现过拟合的现象,因此提出C4.5算法。图1C4.5的属性选择方法——获利比例获利比例=信息增益/分支度IV分支度IV与各分支下的类别数目之比成负相关:假如14个样本一共分4支:划分方法1为:分支1数目:分支2数目:分支......
  • 随机森林算法深入浅出
    目录一随机森林算法的基本原理二随机森林算法的优点1.随机森林算法具有很高的准确性和鲁棒性2.随机森林算法可以有效地避免过拟合问题3.随机森林算法可以处理高维度数据4.随机森林算法可以评估特征的重要性三随机森林算法的缺点1.随机森林算法对于少量数据集表现不佳2.随......