zoukankan      html  css  js  c++  java
  • 冒泡排序(java)

    冒泡排序的思想就是将相邻的两个元素做一次比较, 比较出如果后面元素比前面元素小就交换一次位置;

    经过一趟这样的交换最大的元素就落在了最后面, 所以内层循环的边界也出来了,就是不算经排序后的最后的几个元素 ,即 n - i -  1;

    而外层循环所需要比较到的位置也就是n - 2, 如果超过了则超过了边界;(其中n 是元素的总个数)

    例如有这样一列数:

    38、49、65、76、13、27、30、97

    每趟经过排序如下:

    下面是冒泡排序的算法:

    public class BubbleSort {
        public int[] sort(int[] arrays) {
            int temp = 0;
            for (int i = 0; i < arrays.length - 2; i++) {
                for (int j = 0; j < arrays.length - 1 - i; j++) {
                    if (arrays[j] > arrays[j + 1]) {
                        temp = arrays[j];
                        arrays[j] = arrays[j + 1];
                        arrays[j + 1] = temp;
                    }
                }
            }
            return arrays;
        }
    }

    测试类如下:

    public class Test {
        public static void main(String[] args) {
    
            BubbleSort bubbleSort = new BubbleSort();
            int[] array = createArray();
            long ct1 = System.currentTimeMillis();
            int[] arrays = bubbleSort.sort(array);
            long ct2 = System.currentTimeMillis();
            display(arrays);
            
            System.out.println("所消耗的时间:" + (ct2 - ct1));
            
        }
    
        public static void display(int[] arrays) {
            System.out.println("排序后数据:");
            for (int i = 0; i < arrays.length; i++) {
                System.out.print(arrays[i] + "	");
                if (i % 10 == 0) {
                    System.out.println();
                }
            }
            System.out.println();
        }
    
        public static int[] createArray() {
            int[] array = new int[10000];
            System.out.println("数组中元素是:");
            for (int i = 0; i < 10000; i++) {
                array[i] = (int) (Math.random() * 1000);
                System.out.print(array[i] + "	");
                if (i % 10 == 0) {
                    System.out.println();
                }
            }
            System.out.println();
            return array;
        }
    }

    10000个数经过冒泡排序的时间大约是200ms,而十万个数经过排序的时间大约就是14000ms,由此可见数据量很大条件下冒泡排序的局限性;

  • 相关阅读:
    hiho_1081_最短路径1
    hiho_1079_离散化
    hiho_1078_线段树区间修改
    hiho_1069_最近公共祖先3
    【.netcore学习】.netcore添加到 supervisor 守护进程自启动报错
    【.NetCore学习】ubuntu16.04 搭建.net core mvc api 运行环境
    【.NetCore学习】ASP.NET Core EF Core2.0 DB First现有数据库自动生成实体Context
    【vue基础学习】vue.js开发环境搭建
    【vue学习】vue中怎么引用laydate.js日期插件
    【年终总结】个人的2017年年终总结
  • 原文地址:https://www.cnblogs.com/wangnuo/p/7400163.html
Copyright © 2011-2022 走看看