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

© 一大把手 中级黑马   /  2015-11-16 15:14  /  191 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

//冒泡排序
class MaoPao
{
        public static void bubbleSoft(int[]arr)
        {
        for (int x=0;x<arr.length-1;x++)

    {
            for (int y=0;y<arr.length-x-1;y++ )
                    //-X让每一次比较的元素减少,-1避免角标越界
             {
                    if (arr[y]>arr[y+1])
                     {
                      int temp=arr[y];
                          arr[y]=arr[y+1];
                          arr[y+1]=temp;       
                    }

            }
    }
}
  public static void main(String[] args)
   {
          int []arr={2,8,6,3,7,4,9,5};
          //排序前
          printArray(arr);
    //排序
    bubbleSoft(arr);
    //排序后
    printArray(arr);
  }
    public static void  printArray (int []arr)
    {
            System. out.print("[");
            for (int x=0;x<arr.length ;x++ )
             {
            if (x!=arr.length-1)
                         
             System.out.print(arr[x]+",");       
             else
                       
             System.out.println(arr[x]+"]")        ;
                    }       
            }

    }
//选择排序
class XuanZe
{
        public static void selectSoft(int []arr)
        {
                for (int x=0;x<arr.length-1;x++)
                {
                        for (int y=x+1;y<arr.length;y++)
                        {
                                if(arr[x]>arr[y])
                                {
                                        int temp=arr[x];
                                        arr[x]=arr[y];
                                        arr[y]=temp;

                                }
                        }
                }
        }
        public static void main (String []args)
        {
                int[]arr={2,8,6,3,7,4,9,5};
                selectSoft(arr);
                printArr(arr);
        }
        public static void printArr(int[]arr)
        {
                System.out.print("[");
                for(int x=0;x<arr.length;x++)
                {
                        if(x!=arr.length-1)
                                System.out.print(arr[x]+",");
                        else
                                System.out.println(arr[x]+"]");
                }
        }
}
这两种排序方式差不多,哪种更常用一些?最快捷的排序方式是什么?
       

0 个回复

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