首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么我不能用Insertion排序编码java获得输出?

为什么我不能用Insertion排序编码java获得输出?
EN

Stack Overflow用户
提问于 2015-03-27 04:01:34
回答 1查看 40关注 0票数 0

在实现InsertionSort时,无法获得输出

代码语言:javascript
复制
package app;

public class InsertionSortDemo {

    public static void  insertionsort1(int A[]) {
        int i,j,v;
        for(i=2;i<=A.length-1;i++) {
            v=A[i];
            j=i;
            while(A[j-1]>v && j>=1) {
                A[j]=A[j-1];
                j--;
            }
            A[j]=v;
        }
    }

    public static void main(String s[]) {
        int ar[]={6,8,1,4,5,3,7,2};
        insertionsort1(ar);
    }
}

产出显示:

线程"main“java.lang.ArrayIndexOutOfBoundsException:-1中的异常 在app.InsertionSortDemo.insertionsort1(InsertionSortDemo.java:11) 在app.InsertionSortDemo.main(InsertionSortDemo.java:23)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-27 04:04:13

问题在于:

代码语言:javascript
复制
while(A[j-1]>v && j>=1)

Java中的条件是从左到右计算的。因此,当j的值为0时,您将访问A[-1],从而导致异常。

只需更改验证while循环的方式:

代码语言:javascript
复制
while(j>=1 && A[j-1]>v)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29293063

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档