博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
排序算法之三冒泡排序
阅读量:5082 次
发布时间:2019-06-13

本文共 1465 字,大约阅读时间需要 4 分钟。

冒泡排序介绍

  冒泡排序基本思想:每一次将最大或者最小的数放在队列的最后面。假设数组a中存放了n个数据元素,循环进行n-1趟下列的排序过程:第一趟比较相邻的两个数据元素a[n]和a[n+1]的大小,如果a[n]>a[n+1],就交换两个数据元素,否则就不交换,这样最大的数据元素放在队列的最后边,即a[n-1]位置;第二趟时,数据元素个数减少1,按照第一趟的操作方式获得n个元素中的次大的数据元素放在a[n-2]中,以此类推,直到获得最小的数据元素将其放在a[0]中,排序结束。

  冒泡排序演示过程如下:

初始数据元素:12  32  21  3  74

第一趟排序结果:12  21  3  32  【74】

第二趟排序结果:12  3  21  【32  74】

第三趟排序结果:3  12  【21  32  74】

第四趟排序结果:3  【12  21  32  74】

最终排序结果:3  12  21  32  74

算法实现

/**     * 冒泡排序     * @param array     * @param length     */    private static void bubbleSort(int[] array, int length) {        for(int i=array.length-1;i>0;i--){            for(int j=0;j
array[j+1]){ //交换array[j]与array[j+1]位置 int temp=array[j]; array[j]=array[j+1]; array[j+1]=temp; } } } }

测试代码:

public class SelectSort{    public static void main(String[] args) {        int[] array={12,32,21,3,74};        System.out.printf("排序前:");                //打印排序前数据元素        for(int i=0;i
0;i--){ for(int j=0;j
array[j+1]){ //交换array[j]与array[j+1]位置 int temp=array[j]; array[j]=array[j+1]; array[j+1]=temp; } } } }

结果:

排序前:12 32 21 3 74 排序后:3 12 21 32 74

转载于:https://www.cnblogs.com/sishui-nianhua/p/7751792.html

你可能感兴趣的文章
oracle 报错ORA-12514: TNS:listener does not currently know of service requested in connec
查看>>
python3 生成器与迭代器
查看>>
java编写提升性能的代码
查看>>
list 容器 排序函数.xml
查看>>
《Genesis-3D开源游戏引擎完整实例教程-跑酷游戏篇03:暂停游戏》
查看>>
CPU,寄存器,一缓二缓.... RAM ROM 外部存储器等简介
查看>>
windows下编译FreeSwitch
查看>>
git .gitignore 文件不起作用
查看>>
Alan Turing的纪录片观后感
查看>>
c#自定义控件中的事件处理
查看>>
django Models 常用的字段和参数
查看>>
IOS--沙盒机制
查看>>
使用 JointCode.Shuttle 访问任意 AppDomain 的服务
查看>>
sqlite的坑
查看>>
digitalocean --- How To Install Apache Tomcat 8 on Ubuntu 16.04
查看>>
【题解】[P4178 Tree]
查看>>
Mongo自动备份
查看>>
cer证书签名验证
查看>>
synchronized
查看>>
【深度学习】caffe 中的一些参数介绍
查看>>