zoukankan      html  css  js  c++  java
  • 选择排序(java)

    选择排序的思想是:内外两层循环,第一层循环从第一个数开始到倒数第一个数,

    第二层循环从上一层的数开始, 与上一层循环的数比较,如果小于则交换位置、

    代码如下:

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

    测试类如下:

    package Test;
    
    import org.omg.CORBA.Current;
    
    import bubbleSort.BubbleSort;
    import insertSort.InsertSort;
    import quickSort.QuickSort;
    import selectSort.SelectSort;
    
    public class Test {
        public static void main(String[] args) {
    
            SelectSort selectSort = new SelectSort();    
            int[] array = createArray();
            long ct1 = System.currentTimeMillis();    
            int[] arrays = selectSort.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 + 1) % 10 == 0) {
                    System.out.println();
                }
            }
            System.out.println();
        }
    
        public static int[] createArray() {
            int[] array = new int[100000];    
            System.out.println("数组中元素是:");
            for (int i = 0; i < 100000; i++) {
                array[i] = (int) (Math.random() * 1000);
                System.out.print(array[i] + "	");
                if ((i + 1) % 10 == 0) {
                    System.out.println();
                }
            }
            
            System.out.println();
            return array;
        }
    }

    算法效率和冒泡排序是一样的,进行100000个数的排序要14000ms。

  • 相关阅读:
    Key&Main Window
    ObjectiveC Runtime IV 【使用隐藏的参数】
    JS中的变量作用域
    Git配置
    ObjectiveC Runtime II 【发送消息 vs 调用函数】
    GDB Vs. WinDbg Commands
    mcs51 串口通信 单片机发 pc收
    csharp截屏
    解决WIN7系统中系统文件的“拒绝访问”的方案
    在VC中创建DLL文件的方法步骤
  • 原文地址:https://www.cnblogs.com/wangnuo/p/7401315.html
Copyright © 2011-2022 走看看