[英]Compare two arraylist
我有两个Arraylists:
ArrayList a1 = new ArrayList();
a1.add("5");
a1.add("10");
a1.add("20");
a1.add("50");
a1.add("100");
a1.add("500");
a1.add("1000");
ArrayList a2 = new ArrayList();
a2.add("50");
a2.add("500");
a2.add("1000");
我如何比较这两个arraylists并添加到新的arraylist(a3)中,如果a1存在于a1中则为1,如果不存在则为0,因此结果将在下面为arraylist a3?
a3[0] = 0
a3[1] = 0
a3[2] = 0
a3[3] = 1
a3[4] = 0
a3[5] = 1
a3[6] = 1
提前致谢
首先,我建议你使用泛型 。 其次,因为a2
可能是一个Set
而不是。 第三,您可能希望从String
更改为Integer
(因为它们都是整数)。
但是对于你的例子,这是一种方法:
ArrayList<Integer> a3 = new ArrayList<Integer>();
for (String a : a1)
a3.add(a2.contains(a) ? 1 : 0);
完整示例(使用HashSet
和Integer
类型):
public static void main(String... args) {
List<Integer> a1 = Arrays.asList(5, 10, 20, 50, 100, 500, 1000);
Set<Integer> a2 = new HashSet<Integer>(Arrays.asList(50, 500, 1000));
ArrayList<Integer> a3 = new ArrayList<Integer>();
for (Integer a : a1)
a3.add(a2.contains(a) ? 1 : 0);
System.out.println(a3);
}
输出:
[0, 0, 0, 1, 0, 1, 1]
这样做。
请注意,你的问题指定int[]
作为输出类型,这不是我所选择的 - 列表可能会更好,但是这个答案符合你的要求,不像我到目前为止看到的其他答案。
public static void main(String[] args) {
ArrayList<String> a1 = new ArrayList<String>();
a1.add("5");
a1.add("10");
a1.add("20");
a1.add("50");
a1.add("100");
a1.add("500");
a1.add("1000");
ArrayList<String> a2 = new ArrayList<String>();
a2.add("50");
a2.add("500");
a2.add("1000");
int[] matches = new int[a1.size()];
int i = 0;
for (String s : a1)
matches[i++] = a2.contains(s) ? 1 : 0;
System.out.println(Arrays.toString(matches));
}
输出:
[0, 0, 0, 1, 0, 1, 1]
您可以使用contains(Object o) method of ArrayList
来检查元素是否存在于第二个arraylist中,并相应地将该元素添加到第三个列表中,如:
for(String temp: a1)
{
if(a2.contains(temp))
{
a3.add(1);
}
else
{
a3.add(0);
}
}
Psuedo代码
Check both a1 and a2 for length. say a1 is longest
a3 = new arraylist(a1.length)
for(i=0 to a2.length)
if(a1.contains(a2.get(i))
a3.get(i)++;
像这样的东西:
ArrayList<Integer> a3 = new ArrayList<Integer>();
for (String v : a1) {
if (a2.contains(v)) {
a3.add(1);
} else {
a3.add(0);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.