A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Holmes 中级黑马   /  2015-7-25 11:54  /  501 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

对于任何一个数组排序,都有几种方式:比如选择,比如冒泡等,那么哪种方式排序才是效率最高的呢?以及为什么呢?

3 个回复

倒序浏览
选择排序这个应该比较块
public static void main(String[] args){
      int[] arr = {36,50,3,76,5,0,3,75,5};
     选择排序(arr);
}
public static void 选择排序(int[] arr){
    for(int i = 0 ; i < arr.length-1; i++){

        for(int j = i +1;j < arr.length;j++){
             if(arr[i]>arr[j]){
                   int temp = arr[j];
                   arr[j] = arr[i];
                   arr[i] = temp;
             }
        }
    }
    for(int i = 0 ;i<arr.length;i++){
    System.out.print(arr[i]);
    }
}
这个
回复 使用道具 举报
public class test2 {
//优化后的        选择排序
         public static void main(String[] args){
              int[] arr = {36,50,3,76,5,0,3,75,5};
             选择排序(arr);
        }
         public static void 选择排序(int[] arr){
            for(int i = 0 ; i < arr.length-1; i++){//i1 j 2
                    int temp = arr[i];
                    int index = i;
                for(int j = i +1;j < arr.length;j++){
                     if(temp > arr[j]){
                            temp = arr[j];
                            index = j;
                     }
                }
               arr[index] = arr[i];
               arr[i] = temp;
            }
            for(int i = 0 ;i<arr.length;i++){
            System.out.println(arr[i]);
            }
        }
回复 使用道具 举报
归并排序 > 快速排序 > 希尔排序 > 插入排序 > 选择排序 > 冒泡排序
为什么不是很懂,推荐一篇博文做参照:
http://easense2009.iteye.com/blog/1568614
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马