经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Java » 查看文章
快速排序代码
来源:cnblogs  作者:小毅大师  时间:2018/11/7 0:44:52  对本文有异议

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); //递归重复执行
}

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号