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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© SilentMax 中级黑马   /  2016-5-11 21:07  /  400 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文


/*

数组的排序问题

*/


public class Demo1  {
        public static void main(String[] args) {
                int[] arr = {22,44,55,66,11};
                //bubbleSort(arr);
                selectSort(arr);
                print(arr);
                //System.out.println(getIndex(arr,44));
        }

        //冒泡排序
        public static void bubbleSort(int[] arr){
                for(int i = 0 ;i < arr.length-1;i++){
                        for(int j = 0;j < arr.length-1;j++){
                                if(arr[j] < arr[j + 1]){
                                        swap(arr,j,j+1);
                               
                                }
                       
                        }
               
               
                }

       
        }
        public static void print(int[] arr){
                for(int i = 0 ;i < arr.length;i++){
                        System.out.println(arr[i]);
               
                }
               
               
       
        }
        //选择排序
        public static void selectSort(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]){
                                        swap(arr,i,j);
                               
                                }
                       
                       
                        }
               
               
                }
       
        }

        //数组反转


        public static void swap(int[] arr,int i ,int j){
               
                                        int temp = arr[i];
                                        arr[i] = arr[j];
                                        arr[j] = temp;
       
        }
        //折半查找
        public static int getIndex(int[] arr,int key){
                int min = 0;
                int max = arr.length - 1;
                int mid = (min + max)/2;
                while(arr[mid] != key){
                        if(arr[mid] > key){
                                max = mid - 1;
                       
                        }else if(arr[mid] < key) {
                                min = mid +1;
                       
                        }
                        mid = (min + max)/2;
                        if(min > max){
                                return -1;
                       
                        }
               
                }
                        return mid;
        }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马