java排序
2018-11-09 02:38:14来源:博客园 阅读 ()
双端扫描交换排序
public void sort(int[] item, int start,int end){ if(start < end){ int head = item[start]; int i = start + 1; int j = end; while(i <= j){ while(i <= j && item[i] < head){//条件满足的话,i一直向右走, 直到条件终止(item[i]大于pro) i ++; } //注意: 这里的大小判断用的是大于等于 while(i <= j && item[j] >= head){//条件满足,j一直向左走, 直到条件终止(item[i]小于pro) j --; } //当i,j停止移动,说明item[i]大于pro, item[j]小于pro, 这个时候交换item[i]和item[j]的值 if(i <= j){//交换i j , 小的在左边,大的在右边 int tem = item[i]; item[i] = item[j]; item[j] = tem; } } //当i大于j的时候,将pro和item[j]交换, 这样就形成了以item[j]为分界点, 左边小于item[j], 右边大于item[j] int tem = item[j]; item[j] = head; item[start] = tem; //快排左边 sort(item,start,j-1); //快排右边 sort(item,j+1,end); } }
赋值排序
public void filling(int[] item, int start, int end){ if(start < end){ int head = item[start]; int i = start; int j = end; while(i < j){ while(i < j && item[j] > head){ j --; } item[i] = item[j]; while(i < j && item[i] <= head){ i ++; } item[j] = item[i]; } item[i] = head; filling(item,start,i - 1); filling(item, i + 1, end); } }
参考地址: https://blog.csdn.net/Holmofy/article/details/71168530
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Eclipse的汉化问题
下一篇:Java跳出多重嵌套循环
- 国外程序员整理的Java资源大全(全部是干货) 2020-06-12
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- 2020年java就业前景 2020-06-11
- 04.Java基础语法 2020-06-11
- Java--反射(框架设计的灵魂)案例 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash