快速排序代码

2018-11-09 02:35:42来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

public static void main(String[] args) {
int [] a= {1,3,5,7,9,2,4,6};
Sorts(a,0,a.length-1);
for(int i=0;i<a.length-1;i++) {
System.out.print(a[i]+" ");
}
}

public static void Sorts(int [] a,int start ,int end) {
int i,j,temp;
if(start>end) { //起点终点相遇
return;
}
i=start; //起点(哨兵)
j=end; //终点
temp=a[start];
while(i<j) {
while(temp<=a[j]&&i<j) { //比较右边
j--; //获取到第一个小于哨兵的值
}
while(temp>=a[i]&&i<j) { //比较左边
i++; //获取到第一个大于哨兵的值
}
if(i<j) { //把左右两部分相遇的那2个值交换位置
int k=a[i];
a[i]=a[j];
a[j]=k;
}
a[start]=a[i]; //交换哨兵和中间值得位置
a[i]=temp;
}
Sorts(a,start,j-1); //递归重复执行
Sorts(a,j+1,end); //递归重复执行
}

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:(String)、toString、String.valueOf

下一篇:神经网络