【发布时间】:2016-01-23 17:40:31
【问题描述】:
在两个方向上合并两个列表的有效方法是什么,一个以递增方式,另一个以递减方式。两个列表的长度不同。
List1 = ["eight", "nine"] // first element "eight" should be the starting point
List2 = ["three", "six", "seven", "eight"] // last element "eight" should be the starting point
所以最终的结果是
c= ["eight", "eight", "nine", "seven", "six", "three"]
这不完全是我的代码,但这是一个示例。这里所有列表都是从每个列表的first-element 考虑的。但我需要一个应该是从first-element 到last-element 而另一个从last-element 到first-element
List<String> a = [ "one", "two", "three", "four" ];
List<String> b = [ "fee", "fi" ];
List<String> c = [ "broccoli", "tomato", "potato" ];
List<String> d = [ "purple" ];
Iterator<String> interleaved = Iterators.interleave(
a.iterator(), b.iterator(),
c.iterator(), d.iterator() );
int count = 1;
while ( interleaved.hasNext() ) {
System.out.println( count++ + ": " + interleaved.next() );
}
Output:
1: one
2: fee
3: broccoli
4: purple
5: two
6: fi
7: tomato
8: three
9: potato
10: four
【问题讨论】:
-
你能显示代码吗?
-
你能稍微澄清一下你的问题吗?
-
现在@Mr.Robot 清楚了吗?
-
所以,你几乎已经拥有了你想要的东西,但只是想让一些迭代器反向迭代,而不调用
Collections.reverse(),是这样吗? -
我认为
Iterators.interleave()尚未实现。你也必须自己实现那个。