当前位置:   article > 正文

C#算法之冒泡排序算法

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. }

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/484637
推荐阅读
相关标签
  

闽ICP备14008679号