关闭

冒泡排序算法

300人阅读 评论(0) 收藏 举报
分类:

经典排序算法 - 冒泡排序Bubble sort

原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换,

这样一趟过去后,最大或最小的数字被交换到了最后一位,

然后再从头开始进行两两比较交换,直到倒数第二位时结束,其余类似看例子

例子为从小到大排序,

原始待排序数组| 6 | 2 | 4 | 1 | 5 | 9 |

第一趟排序(外循环)

第一次两两比较6 > 2交换(内循环)

交换前状态| 6 | 2 | 4 | 1 | 5 | 9 |

交换后状态| 2 | 6 | 4 | 1 | 5 | 9 |

第二次两两比较,6 > 4交换

交换前状态| 2 | 6 | 4 | 1 | 5 | 9 |

交换后状态| 2 | 4 | 6 | 1 | 5 | 9 |

第三次两两比较,6 > 1交换

交换前状态| 2 | 4 | 6 | 1 | 5 | 9 |

交换后状态| 2 | 4 | 1 | 6 | 5 | 9 |

第四次两两比较,6 > 5交换

交换前状态| 2 | 4 | 1 | 6 | 5 | 9 |

交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

第五次两两比较,6 < 9不交换

交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |

交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

第二趟排序(外循环)

第一次两两比较2 < 4不交换

交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |

交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

第二次两两比较,4 > 1交换

交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

第三次两两比较,4 < 5不交换

交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |
交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

第四次两两比较,5 < 6不交换

交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |

交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

第三趟排序(外循环)

第一次两两比较2 > 1交换

交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

第二次两两比较,2 < 4不交换

交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

第三次两两比较,4 < 5不交换

交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

第四趟排序(外循环)无交换

第五趟排序(外循环)无交换

排序完毕,输出最终结果1 2 4 5 6 9

代码仅供参考

复制代码
static void bubble_sort(int[] unsorted)
{
for (int i = 0; i < unsorted.Length; i++)
{
for (int j = i; j < unsorted.Length; j++)
{
if (unsorted[i] > unsorted[j])
{
int temp = unsorted[i];
unsorted[i] = unsorted[j];
unsorted[j] = temp;
}
}
}
}

    static void Main(string[] args)
    {
        int[] x = { 6, 2, 4, 1, 5, 9 };
        bubble_sort(x);
        foreach (var item in x)
        {
            Console.WriteLine(item);
        }
        Console.ReadLine();
    }

复制代码

冒泡排序动画演示

bubble_sort_animation
这里写图片描述

0
0
查看评论

排序算法之(1)——冒泡排序

**【冒泡排序的思想】** 冒泡排序总共进行n-1趟,每一趟扫描总是通过两两比较把大的往后放,所以第一趟即把最大数放在最后面,接着第二趟把第二大数放在倒数第二的位置………….到n-1完成,此时只有一个数未排序,这个数就是最小元素,不再需要扫描,此时完成对所有元素的排序。
  • adminabcd
  • adminabcd
  • 2015-06-06 10:11
  • 865

请编程实现一个冒泡排序算法?

int [] array = new int ; int temp = 0 ; for (int i = 0 ; i { for (int j = i + 1 ; j { if (array[j] { temp = array[i] ; array[i] = array[j]...
  • X_X_OO
  • X_X_OO
  • 2016-09-13 19:36
  • 1885

java 排序算法实现 其一:冒泡排序

冒泡排序法的java和C++实现
  • sinat_22013331
  • sinat_22013331
  • 2014-10-17 11:52
  • 310

冒泡排序算法的c语言实现

冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。 然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后...
  • lickylin
  • lickylin
  • 2012-09-23 20:49
  • 5959

有意思的算法(一)----冒泡排序

冒泡排序的基本思想是:每次比较两个相邻的元素,如果它们的顺序错误就把他们交换过来。     下面举一个具体的例子来介绍一下冒泡排序。    有12,35,99,18,76五个数进行从大到小的排序,既然是从大到小排序,也就...
  • u010853701
  • u010853701
  • 2015-10-30 20:28
  • 2321

JAVA语言编写的冒泡排序算法

JAVA语言编写的冒泡排序算法
  • ITofwanyifei
  • ITofwanyifei
  • 2014-06-03 18:27
  • 929

排序算法c语言描述---冒泡排序

排序算法系列学习,主要描述冒泡排序,选择排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序等排序进行分析。 文章规划: 一。通过自己对排序算法本身的理解,对每个方法写个小测试程序。 具体思路分析不展开描述。 二。通过《大话数据结构》一书的截图,详细分析该算法 。  在此,推...
  • hitwhylz
  • hitwhylz
  • 2013-08-05 22:16
  • 8851

单链表实现冒泡排序算法

下面实现主要采用交换指针的方法,其中附加有单链表及其相关的实现 [cpp] view plain copy #include       struct Node; ...
  • zhengqijun_
  • zhengqijun_
  • 2016-10-15 19:54
  • 1582

排序算法系列:冒泡排序与双向冒泡排序

**排序算法**应该算是一个比较热门的话题,在各个技术博客平台上也都有一些博文进行了一定程度的讲解。但还是希望能从自我完善的角度出发,可以更详细、全面、形象地表达这些算法的精髓。本文就先从最简单的冒泡排序开始说起,别说你已经彻底了解了冒泡排序算法(虽然一开始我也是这样以为的)。
  • u013761665
  • u013761665
  • 2016-01-29 15:25
  • 9737

改进版的冒泡排序(双向冒泡算法)

#include "stdafx.h" #include #include   //一般的冒泡排序 void bubbleSort(int a[], int n) {  ...
  • Game_jqd
  • Game_jqd
  • 2016-02-02 20:37
  • 643
    个人资料
    • 访问:124834次
    • 积分:2155
    • 等级:
    • 排名:千里之外
    • 原创:77篇
    • 转载:14篇
    • 译文:0篇
    • 评论:66条
    最新评论