Java排序算法: 冒泡排序

public class BubbleSort
{
    public static void main(String[] args)
    {
        int[] array = {2,1,6,20,10,34,9,3,-5,100};
        long startTime = System.nanoTime();    
        int[] sortedArray = getBubbleSort(array);    
        long stopTime = System.nanoTime();
        System.out.print("Sorted Array:");
        for (int sort : sortedArray)
        {
            System.out.print(" " + sort);
        }
        System.out.println();
        System.out.println("Start Time: " + startTime);
        System.out.println("Stop  Time: " + stopTime);
        System.out.println("Execute Time: " + (stopTime - startTime));
    }
    
    private static int[] getBubbleSort(int[] array)
    {
        for (int i = 0;i < array.length;i++)
        {
            for(int j = i + 1 ;j < array.length;j++)
            {
                if (array[i] > array[j])
                {
                    int temp = array[i];
                    array[i] = array[j];
                    array[j] = temp;
                }
            }
        }
        
        return array;
    }
}

运行结果:

Sorted Array: -5 1 2 3 6 9 10 20 34 100
Start Time: 4130270236414
Stop  Time: 4130270239695
Execute Time: 3281

除排序后输出的结果是一样的,其它的三项数值即使在同一台机器测试多次结果都会不同,不过Execute Time偶尔会有相同。

本想用System.currentTime(),但机器执行太快了,差值是0。所以用了更精确的方法nanoTime(),精确到纳秒级别。这个方法

是JDK1.5后才有。

System是一个final 类,其中的方法之一是:  public static native long nanoTime();

nanoTime是一个 native  method,在linux下实现,会调用clock_gettime()系统函数。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值