文章详情页
java中关于直接插入排序遇到的问题。
浏览:99日期: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. 主从备份 - 跪求mysql 高可用主从方案2. python - django 里自定义的 login 方法,如何使用 login_required()3. python如何不改动文件的情况下修改文件的 修改日期4. android-studio - Android 动态壁纸LayoutParams问题5. javascript - git clone 下来的项目 想在本地运行 npm run install 报错6. angular.js - 不适用其他构建工具,怎么搭建angular1项目7. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?8. mysql优化 - mysql count(id)查询速度如何优化?9. node.js - 使用 superagent 抓取 UTF-8网站乱码10. sql语句如何按or排序取出记录
排行榜
