1

我正在尝试在 ArrayList 中搜索“装箱”的整数,并将最小值放入列表的前面。但是,当有新的分钟时,它似乎没有放在前面。

以下是一些示例:例如,如果名为 list 的变量存储以下值:{3, 8, 92, 4, 2, 17, 9} 并且您进行此调用: minToFront(list); 它应该在调用后存储以下值: {2, 3, 8, 92, 4, 17, 9} 假设列表至少存储一个值。

private static void minToFront(ArrayList<Integer> thing) {
    int tempMin = Integer.MAX_VALUE;
    for (int i = 0; i < thing.size(); i++) {
        if (tempMin < thing.get(i)) {
            thing.add(0,thing.get(i));
            thing.remove(i+1);
            i++;
        }
    }
}
4

2 回答 2

3

你的逻辑有点不对劲。看看你的 if 语句:

if (tempMin < thing.get(i)) {

您在询问列表元素是否大于最大 int 值,这永远不会是真的。您需要完全遍历列表一次以找到最小值及其位置,然后对列表进行操作。

if (thing.size() < 2)  // special case
    return;

int min = thing.get(0), minLoc = 0;

for (int i = 1; i < thing.size(); i++) {
    int next = thing.get(i);

    if (next < min) {
        min = next;
        minLoc = i;
    }
}

thing.add(0, thing.remove(minLoc));
于 2013-10-05T03:03:43.520 回答
0
public static void minToFront(ArrayList<Integer> arrayList){
    if(arrayList.size() == 0) {
        System.out.println("Array is empty");
    }
    else {
        int min = arrayList.get(0);
        int index = 0;
        for (int i = 0; i < arrayList.size(); i++) {
            if (arrayList.get(i) < min)
                min = arrayList.get(i);
        }
        index = arrayList.indexOf(min);
        arrayList.remove(index);
        arrayList.add(0, min);
    }
}

输入:[3、8、92、4、2、17、9]

输出:[2、3、8、92、4、17、9]

于 2020-02-09T07:47:43.380 回答