码迷,mamicode.com
首页 > 编程语言 > 详细

快速排序

时间:2017-03-05 23:23:21      阅读:253      评论:0      收藏:0      [点我收藏+]

标签:rac   hit   cas   排序算法   down   eid   outline   ase   amp   

 


快速排序

对于一个int数组,请编写一个快速排序算法,对数组元素排序。

给定一个int数组A及数组的大小n,请返回排序后的数组。

测试样例:
[1,2,3,5,2,3],6
[1,2,2,3,3,5]
 
 
1
import java.util.*;
2

3
public class QuickSort {
4
    public int[] quickSort(int[] A, int n) {
5
        int left = 0;
6
        int right = n-1;
7
        return quickSort(A, left, right);
8
    }
9
    public int[] quickSort(int[] A, int left, int right){
10
        if(left < right){
11
            int i = left;
12
            int j = right;
13

14
            int target = A[i];
15

16
            while(i < j){
17
                while(j>i && A[j]>target){
18
                    j--;
19
                }
20
                if(j>i){
21
                    A[i] = A[j];
22
                    i++;
23
                }
24
                while(i<j && A[i]<target){
25
                    i++;
26
                }
27
                if(i<j){
28
                    A[j] = A[i];
29
                    j--;
30
                }
31
            }
32
            A[i] = target;
33
            quickSort(A, left, i-1);
34
            quickSort(A, i+1, right);
35

36
        }
37
        return A;
38
    }
39
}
 
 
您的代码已保存
答案正确:恭喜!您提交的程序通过了所有的测试用例

快速排序

标签:rac   hit   cas   排序算法   down   eid   outline   ase   amp   

原文地址:http://www.cnblogs.com/haozhengfei/p/791a7782c127aea3485289b09dff56d5.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!