java核心技术之冒泡排序算法

这里写图片描述

写在前面的话:

这个星期,在网上买了一本《java常用算法手册》。稍微看了一下,觉得这本书对于算法的分析还是比较详细清楚的,算法的种类也是相当的齐全,但是java的代码算法实现,确实是让人不敢恭维。这说明这几个作者是没有看过《代码大全2》和《代码重构》,我这也正好借这次机会,好好的学习一下java的基本算法实现,做一个简单的总结。先从最简单的冒泡排序算法开始这次java算法学习吧。

1 冒泡排序算法(Bubble Sort)

冒泡排序算法的思路是交换排序,通过相邻数据的交换来达到排序的目的。是所有排序算法中最简单,最基本的一种。

2.冒泡算法的排序流程

(1)对数组中的各个数据,依次比较相邻的两个元素的大小。
(2)如果前面的数据大于后面的数据,就交换这二个数据。经过第一轮的多次比较交换排序后,便可以将最小的数据排到第一位。
(3)再用同样的方法把剩下的数据逐个进行比较,最后便可按照从小到大的顺序排好数组各个数据。

3.冒泡排序算法之java实现

public class BubbleSort {
    public int[] doSort(int[] array){       
        int temp;
        for(int i=0;i<array.length;i++){
            for(int j=0;j<array.length-1-i;j++){
                if(array[j]>array[j+1]){
                    temp = array[j];
                    array[j] = array[j+1];
                    array[j+1] = temp;
                }
            }
            System.out.print("第"+i+"步排序结果:\n");
            for(int k=0;k<array.length;k++){
                System.out.print(" "+array[k]);
            }
            System.out.print("\n");
        }
        return array;   
    }
}
public class Sort {
    private static final int size = 5;
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int[] array = new int[size];
        for(int i=0;i<size;i++){
            array[i] = (int)(100+Math.random()*(100+1));
        }
        System.out.print("排序前的数组为:\n");
        for(int k=0;k<array.length;k++){
            System.out.print(" "+array[k]);
        }
        System.out.print("\n");     
        BubbleSort bubbleSort = new BubbleSort();
        array = bubbleSort.doSort(array);       
        System.out.print("排序后的数组为:\n");
        for(int k=0;k<array.length;k++){
            System.out.print(" "+array[k]);
        }
        System.out.print("\n");
    }
}

程序结果:

排序前的数组为:
124 175 157 194 141
第0步排序结果:
124 157 175 141 194
第1步排序结果:
124 157 141 175 194
第2步排序结果:
124 141 157 175 194
第3步排序结果:
124 141 157 175 194
第4步排序结果:
124 141 157 175 194
排序后的数组为:
124 141 157 175 194

4.冒泡算法改进

在《java常用算法手册》中,提出了一种改进的冒泡算法:在每次中间排序之后,比较一下数据是否已经按照顺序排列完成。如果排列完成则不再排序,否则便继续进行冒泡排序。这样对于数据比较有规则的数据,可以加速算法的执行过程。但是代价是会加多一下算法的复杂度。这个不怎么重要,我不打算实现。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hfreeman2008

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值