码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C#算法之冒泡排序算法


            创作灵感:数据处理过程中,最常见的就是排序问题,排序的方式由很多种,我会同各位朋友进行逐一的探讨,首先从比较简单的冒泡排序算法说起。

            冒泡排序:是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

            示例代码如下:

    1. using System;
    2. class Program
    3. {
    4. static void Main()
    5. {
    6. int[] arr = { 64, 34, 25, 12, 22, 11, 90 };
    7. BubbleSort(arr);
    8. Console.WriteLine("Sorted array is:");
    9. foreach (int item in arr)
    10. {
    11. Console.Write(item + " ");
    12. }
    13. }
    14. static void BubbleSort(int[] arr)
    15. {
    16. int n = arr.Length;
    17. bool swapped;
    18. for (int i = 0; i < n - 1; i++)
    19. {
    20. swapped = false;
    21. for (int j = 0; j < n - i - 1; j++)
    22. {
    23. if (arr[j] > arr[j + 1])
    24. {
    25. // 交换 arr[j] 和 arr[j + 1]
    26. int temp = arr[j];
    27. arr[j] = arr[j + 1];
    28. arr[j + 1] = temp;
    29. swapped = true;
    30. }
    31. }
    32. // 如果在这一轮排序中没有交换过,说明数组已经有序,可以提前结束
    33. if (!swapped)
    34. break;
    35. }
    36. }
    37. }

            冒泡排序在最坏情况下效率不高,但它对于小数据集或基本有序的数据集来说是一个不错的选择。此外,冒泡排序是稳定的排序算法,这意味着相等的元素在排序后会保持它们原始的顺序。

            冒泡排序可以通过记录最后一次交换的位置来优化,因为在这个位置之后的元素已经在前面的迭代中被排序好了,所以不需要再次检查。这样可以减少不必要的比较,从而提高效率。

  • 相关阅读:
    索尼 toio™ 应用创意开发征文|探索创新的玩乐世界——索尼 toio™
    【重铸Java根基】理解Java反射机制
    MATLAB与Python:优势与挑战
    ubuntu 解压zip文件时,出现乱码
    【软考】9.3 二叉树存储/遍历/线索/最优/查找/平衡
    【eCharts】第三部分 在同一个容器中展示多个图表
    面了一位5年老测试哥们,只会功能测试,敢要17K薪资,自认为挺牛逼的......
    关于计算机网络
    练习编程题-第一期
    MogaFX外汇储备以一年多来的最快速度增长
  • 原文地址:https://blog.csdn.net/weixin_50236846/article/details/138078227
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号