`
jackroomage
  • 浏览: 1197429 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

java快速排序问题

阅读更多
public class Point{
    public static void main(String[] args) {
        int[] a = {4,63,2,4,4,6,43,2,3};
        quickSort(a, 0, a.length - 1);
       
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i] + ",");
        }
    }
    static int Partition(int[] a, int left, int right)
    {
        int tmp;
       
        //进行一趟快速排序,返回中心记录位置
        int pivot = a[left];//把中心置于a[0]
        while (left < right)
        {
            while(left<right && a[right]>=pivot)
                right--;
            //将比中心记录小的移到低端
            tmp = a[right];
            a[right] = a[left];
            a[left] = tmp;
            while(left<right && a[left]<=pivot)
                left++;
            tmp = a[right];
            a[right] = a[left];
            a[left] = tmp;
           //将比中心记录大的移到高端
        }
        a[left] = pivot; //中心移到正确位置
        return left;  //返回中心位置
    }
   
    public static void quickSort(int[] a, int left, int right) {
        if(left >= right - 1)
            return;

        int pivot = Partition(a,left,right);
        quickSort(a, left, pivot-1);
        quickSort(a, pivot+1, right);  
    }
}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics