文章详情页
java中关于直接插入排序遇到的问题。
浏览:256日期:2024-02-05 09:40:18
问题描述
在研究直接插入排序的时候,写了个代码,如下:
static void zjcr1(int[] a) {int i,j,temp;//由于比较的时a[j]>a[j+1],所以i的循环条件是a.length-1for(i=1;i<a.length-1;i++){for(j=0;j<i+1;j++) {if(a[j]>a[j+1]){ temp = a[j+1]; a[j+1] = a[j]; a[j] = temp;} }} }
只看逻辑的话if(a[j]>a[j+1])这个地方是不可以完成排序的,但是,实际代码执行后,可以完成数组的排序,看了好久页没看明白,大家帮忙看一下。。。
问题解答
回答1:你用的测试用例不对,试试这个
new int[] {3,2,4,1,7,0,5}
结果:
[1, 2, 3, 0, 4, 5, 7]
建议还是用比较标准的排序方式
标签:
java
相关文章:
1. redis sentinel怎么跑守护进程以及日志记录位置的?2. django - Nginx uwsgi 进程问题3. javascript - sublime快键键问题4. 前端 - 这段代码一直生效不了,查半天因为 top: 0px; 分号后一个隐藏的东西,也不是占位符...删了就可以生效,这是什么情况。。5. javascript - 爱加密的HTML5应用加固服务是什么原理?6. 微信小程序支持跳转到外部链接网页吗7. javascript - 求助关于js正则问题8. 关于纯用css写导航鼠标移入事件的问题?9. 百度地图api - Android百度地图SDK,MapView上层按钮可见却不可触,怎么解决?10. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?
排行榜

网公网安备