![](/img/trans.png)
[英]How can I determine whether one list is contained in another, in the same order (in Java)?
[英]How can I verify that a list elements are in same order of another list or not?
list1 [1,2,3,4,5,6] --基本列表
list2 [1,2,4,3,6,5]
output:4,6 的顺序不正确
我必须检查订单应该按照list1。 如果不是,那么我必须按照 list1 打印所有顺序不正确的元素。
遍历两个列表并打印不同的元素非常简单,但似乎您只想 output 不同的元素一次。 为此,您需要跟踪您已经看到的内容,例如使用Set
。
static void listCompare(List<Integer> list1, List<Integer> list2)
{
Set<Integer> seen = new HashSet<>();
int minLen = Math.min(list1.size(), list2.size());
for(int i=0; i<minLen; i++)
{
if(list1.get(i) != list2.get(i) && !seen.contains(list2.get(i)))
{
seen.add(list1.get(i));
System.out.format("%d (%d)%n", list2.get(i), list1.get(i));
}
}
}
测试:
List<Integer> list1 = Arrays.asList(1,2,3,4,5,6);
List<Integer> list2 = Arrays.asList(1,2,4,3,6,5);
listCompare(list1, list2);
Output:
4 (3)
6 (5)
您可以使用列表迭代器将 list1 的值与 list2 进行比较,如果比较结果为 false,则可以打印 list2 的值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.