- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我不断得到
线程“main”中出现异常 java.lang.ArrayIndexOutOfBoundsException:MergeSorter.merge(MergeSorter.java:44)、MergeSorter.sort(MergeSorter.java:16)、MergeSorter.sort(MergeSorter.java:14) 处的索引 2 超出长度 2 的范围,MergeSorter.sort(MergeSorter.java:14), MergeSorter.sort(MergeSorter.java:14)
不知道如何修复。
之后还想转换为通用。
public class MergeSorter {
////change back to generic later
///array is item
public static void sort(int[] array, int begIndx, int endIndx) {
if (array == null) {
throw new IllegalArgumentException("Item is null.");
}
if(begIndx < endIndx) {
int midIndx = (int) Math.floor((begIndx + endIndx)/2);
sort(array, begIndx, midIndx);
sort(array, midIndx + 1, endIndx);
merge(array, begIndx, midIndx, endIndx);
}
}
//Takes to sorted arrays and merges them together
///Change type of array to generic later
public static void merge(int[] array, int begIndx, int midIndx, int endIndx) {
int sizeOfLeft = midIndx - begIndx + 1;
int sizeOfRight = endIndx - midIndx;
///change to generic later
int[] leftArr = new int[sizeOfLeft + 1];
int[] rightArr = new int[sizeOfRight + 1];
//removing equal sign from loop does nothing
for(int i = 1; i <= sizeOfLeft; i++) {
leftArr[i] = array[begIndx + i - 1];
}
for( int j = 1; j <= sizeOfRight; j++) {
rightArr[j] = array[midIndx + j];
}
leftArr[sizeOfLeft + 1] = Integer.MAX_VALUE;
rightArr[sizeOfRight + 1] = Integer.MAX_VALUE;
int i = 1;
int j = 1;
for(int k = begIndx; k < endIndx; k++) {
//use comparable here
if(leftArr[i] <= rightArr[j]) {
array[k] = leftArr[i];
i = i + 1;
}else {
///just replaces it so don't use comparable
array[k] = rightArr[j];
j = j + 1;
}
}
}
}
最佳答案
数组索引始终从零开始,因此如果您想访问数组中的第二个元素,则需要提供索引 1
。
如果您想按单个值扩展数组,您可以按如下方式创建一个临时数组:
public int[] expand(int[] arrayIn) {
int[] temp = new int[arrayIn.length + 1];
for (int i = 0; i < arrayIn.length; i++) {
temp[i] = arrayIn[i];
}
temp[arrayIn.length] = -1; // You can replace this with another "blank" value
}
因此,返回一个具有扩展索引读数的新数组(在本例中为-1
。
关于MergeSort算法中的Java IndexOutOfBoundsException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56203297/
这个问题已经有答案了: What causes a java.lang.ArrayIndexOutOfBoundsException and how do I prevent it? (25 个回答)
((fn [coll] (letfn [(add-item [acc coll idx] (conj acc (nth coll idx))
我不是 Java 初学者,但也不是专家,这就是我发布此文章以寻求帮助/解释的原因。我在互联网上查找了很多地方,但没有找到我正在寻找的答案。 public class Driver { public s
我不断得到 线程“main”中出现异常 java.lang.ArrayIndexOutOfBoundsException:MergeSorter.merge(MergeSorter.java:44)、
我做了一个小射击游戏..它工作正常但我也想实现如果火相交它们会消失。我有两个播放器子弹列表和计算机子弹列表......但是如果我有更多来自计算机或反向的子弹。这是我的循环 for (int
我试图从 JOptionPane 读取像 3+9-2*10/5 这样的数学表达式并得到它的结果——当然要考虑到操作顺序。我使用 String.split() 将字符串拆分为数字和操作数,并创建了一个寻
我在Grails中有以下代码: public LibraryItem createLibraryItemWithValues(ProjectItem projectItem) { def li
这个问题已经有答案了: What is a debugger and how can it help me diagnose problems? (3 个回答) 已关闭 7 年前。 我有一组以下类型的
请看下面的代码 DatabaseHandler.java public List getDetails(String name) { List details = new Ar
我应该让蛇形矩形沿着屏幕的一侧移动。然而它保持在原位,当我运行它时,我还收到 IndexOutOfBoundsException 错误。我相信这与我的 Render.java 文件中的 for 循环有
ArrayList beds = new ArrayList(49); public Patient getPatient(int bedNumber) { if (beds.get(bedN
我有 10 张卡片的数组。在“回合”的过程中,我向数组添加一张卡片,然后从数组中删除一张卡片(并不总是相同的)。该代码在前 6-7 回合中效果很好,然后抛出 IndexOutofBoundsExcep
我正在尝试创建一个评分系统并获得最佳分数,但我的方法生成了 IndexOutOfBoundsException,但我找不到超出数组列表范围的内容,有人可以帮助我吗? 代码: public stati
为什么 int row = 1; // multiArray[col].length = 6 while(multiArray[col][row] > 1 && row 1) { 关于java -
我制作了一款游戏,我们控制一艘宇宙飞船,可以发射激光摧毁来自顶部的小行星。但在游戏过程中,每当它抛出 IndexOutOfBoundsException 时,我的游戏就会卡住。我不知道为什么会这样。请
我正在尝试实现合并排序,但我不断收到 IndexOutOfBoundsException 并且我无法找出原因。 我已经调试了我的程序,并且在此函数中我从未使用无效索引访问数组。引发异常的行也与抛出异常
我无法弄清楚为什么我的代码出现 IndexOutOfBoundsException。我想知道是否有人可以成为我的额外眼睛来帮助我发现错误。我正在手动尝试这个,但我认为在浏览代码时我遗漏了一些东西。 代
为什么我会收到此错误? Caused by: java.lang.IndexOutOfBoundsException: Invalid index 1, size is 0 at java.util.
我不知道这是否是一个简单的问题,但我只是看不出问题是什么。我现在从 Google Play 中的应用收到了三份关于 points.get(++i) 处的 IndexOutOfBoundsExcepti
如何执行以下内容 String p = "abcd"; System.out.print(p.substring(4)); 不会导致java.lang.IndexOutOfBoundsExceptio
我是一名优秀的程序员,十分优秀!