java - 有效地将元素添加到列表顶部

标签 java list arraylist enums linked-list

我有一个像这样的 ENUM,从中我总是可以得到我的 localFruit ,它可以是 APPLEORANGE香蕉

public enum Fruits {
    // it can have more elements here
    APPLE, ORANGE, BANANA;

    // some code
}

假设 APPLE 是我的 localFruit,那么 ORANGEBANANA 将是我的 remoteFruits。我需要随机播放我的 remoteFruits,然后确保我的 localFruit 位于列表顶部,然后是 remoteFruits

下面是我正在进行洗牌并添加原始 结果 列表的代码:在下面的代码中,CURRENT_FRUIT 可以是 APPLE橙色香蕉

private static List<Fruits> getFruitsInOrder() {
    EnumSet<Fruits> localFruit = EnumSet.of(CURRENT_FRUIT);
    EnumSet<Fruits> remoteFruits = EnumSet.complementOf(localFruit);

    List<Fruits> result = new ArrayList<Fruits>(remoteFruits);
    Collections.shuffle(result);

    // first element in the list will always be the local fruit
    result.addAll(0, new ArrayList<Fruits>(localFruit));
    return result;
}

由于这段代码会被调用很多次,所以想看看我正在做的事情是否有什么问题可能会成为性能瓶颈?我的代码在性能方面还可以吗?

我的主要目标是将 localFruit 放在列表顶部,然后是 remoteFruits (但这在添加到我的结果列表之前我需要对它们进行洗牌)。

最佳答案

所有这些解决方案都太费力了。 Java 集合非常高效,但简单的数组访问效率更高。此外,构建两个集合(一个具有补码操作),复制到 ArrayList,然后使用 addAll 创建一个新的 ArrayList 会产生大量无用的工作和内存垃圾。

枚举按顺序提供了其值的数组。用它!只需将本地元素交换到位置零,然后对数组的其余部分进行洗牌。这样,您就创建了一个数据结构:您想要返回的 ArrayList。剩下的只是重新排序其元素。

当然,除非您有一个巨大的枚举或调用此函数数百万次,否则此讨论是学术性的。您不会注意到性能差异。

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

enum Fruit { APPLE, PEAR, PEACH, PLUM, BANANA }

public class Hack {

    static List<Fruit> getFruitInOrder(Fruit local) {
        List<Fruit> list = Arrays.asList(Fruit.values());
        Collections.swap(list, 0, local.ordinal());
        Collections.shuffle(list.subList(1, list.size()));
        return list;
    }

    public static void main(String[] args) {
        for (int i = 0; i < 10; i++) {
            System.out.println(getFruitInOrder(Fruit.PLUM));
        }
    }
}

在我的 MacBook 上:

run:
[PLUM, BANANA, PEAR, APPLE, PEACH]
[PLUM, PEACH, PEAR, APPLE, BANANA]
[PLUM, PEACH, BANANA, PEAR, APPLE]
[PLUM, PEAR, BANANA, APPLE, PEACH]
[PLUM, PEAR, APPLE, BANANA, PEACH]
[PLUM, BANANA, APPLE, PEACH, PEAR]
[PLUM, APPLE, BANANA, PEACH, PEAR]
[PLUM, APPLE, PEACH, PEAR, BANANA]
[PLUM, APPLE, PEAR, PEACH, BANANA]
[PLUM, PEACH, APPLE, PEAR, BANANA]
BUILD SUCCESSFUL (total time: 0 seconds)

关于java - 有效地将元素添加到列表顶部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30633084/

相关文章:

java - 如何在 Android 上使用 Jackson 将 JSON 数组解析为不同的对象?

java Swing 。如何等待其他 Jframes

java - 无限 while 循环以及读取文件时出现问题

java - 在双链表中插入新元素

c++ - 使用条件变量的单生产者多消费者缓冲区 pthread 实现

Java int 值类型转Character

java - 读取超过 90k 条记录的 Excel 文件时出现内存不足异常

python-3.x - 使用列表理解中的错误处理将字符串转换为 float

java - 将一些 Java 转换为 C#

java - 找不到符号 ArrayList