java - 混合两个通用列表java

标签 java list generics arraylist

我有一个任务,我需要编写一个方法来混合两个通用列表并返回一个新的混合列表。

混合列表应该将 l1 的第一个元素放在新混合列表的第一个位置,l2 的第一个元素应该在第二个位置,然后 l1 的第二个元素应该在第三个位置,依此类推。

如果一个列表比另一个长,则应按原始顺序添加其余列表。

一个例子是:l1 = (1,2,3) and l2=(9,8) --> 混合列表 = (1,9,2,8,3)

public <S, T> List<T> listeMischen(List<S> l1, List<T> l2) {
    List<T> newlist = new ArrayList<T>();
    for(int i = 0; i < l1.size(); i++)
    { 
        for(int j = 0; j < l2.size(); j++) {
            newlist.add(charAt(i));
            newlist.add(charAt(j));
        }           
    }
    return newlist;
}

附言我不知道如何正确添加元素,因为它们是通用的。我输入了绝对错误的“charAt”方法,只是为了展示如果类型不是通用的而是字符,我会尝试做什么。 然而,由于这些元素可以是通用的,所以我非常不确定该怎么做。

最佳答案

这将返回两个参数列表的通用类型的公共(public)父类(super class)型列表:

public <R, S extends R, T extends R> List<R> listeMischen(List<S> l1, List<T> l2) {
    List<R> newList = new ArrayList<>(l1.size() + l2.size());
    int sizeOfLargerList = Math.max(l1.size(), l2.size());
    for (int i = 0; i < sizeOfLargerList; i++) {
        if (i < l1.size())
            newList.add(l1.get(i));
        if (i < l2.size())
            newList.add(l2.get(i));
    }
    return newList;
}

用法:

public static void main(String[] args) {
    List<Number> list = listeMischen(Arrays.asList(1, 2, 3), Arrays.asList(4.5, 5.5, 6.5, 7.5, 8.5));
    System.out.println(list);
}

预期输出==实际输出:

[1, 4.5, 2, 5.5, 3, 6.5, 7.5, 8.5]


更新:添加考虑评论的优化方法

下面显示了该方法的两个重载:一个用于随机访问列表(例如 ArrayList),另一个用于任何旧的可迭代类型,并针对每种类型优化了主体。

static <R> List<R> listeMischen(List<? extends R> l1, List<? extends R> l2) {
    if (!(l1 instanceof RandomAccess && l2 instanceof RandomAccess))
        return listeMischen((Iterable<? extends R>) l1, (Iterable<? extends R>) l2);

    // Preallocate with known exact required capacity
    List<R> newList = new ArrayList<>(l1.size() + l2.size());
    int sizeOfSmallerList = Math.min(l1.size(), l2.size());
    int i;
    // Zip the lists up to common maximum index
    for (i = 0; i < sizeOfSmallerList; i++) {
        newList.add(l1.get(i));
        newList.add(l2.get(i));
    }
    // Add any remaining items from one or the other list
    for (; i < l1.size(); i++)
        newList.add(l1.get(i));
    for (; i < l2.size(); i++)
        newList.add(l2.get(i));
    return newList;
}

static <R> List<R> listeMischen(Iterable<? extends R> l1, Iterable<? extends R> l2) {
    List<R> newList = new ArrayList<>();
    Iterator<? extends R> it1 = l1.iterator();
    Iterator<? extends R> it2 = l2.iterator();
    // Zip the lists up to common maximum index
    while (it1.hasNext() && it2.hasNext()) {
        newList.add(it1.next());
        newList.add(it2.next());
    }
    // Add any remaining items from one or the other lists
    it1.forEachRemaining(newList::add);
    it2.forEachRemaining(newList::add);
    return newList;
}

关于java - 混合两个通用列表java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48325885/

相关文章:

java - 如何在Java中使用泛型类的父类(super class)型?

python - 比较包含 NaN 的列表

java - 如何从 _within_ build.xml 模拟 "-lib foo.jar"

java - 如何将 Flux<List<T>> 扁平化为 Flux<T>?

java - 与 Java 中的文字术语混淆

c++ - 为什么C++不允许派生类在初始化列表中使用基类成员?

c# - 列表的通用列表<T>

java - 通过 varargs 参数可能造成堆污染

Scala 高级类型语法

java - 我无法从 java 运行 python 脚本,我认为这是因为该脚本没有执行权限