我有两个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)中,如果a2中存在a2则为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
提前致谢
答案 0 :(得分:11)
首先,我建议你use generics。其次,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]
答案 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]
答案 2 :(得分:1)
您可以使用contains(Object o) method of ArrayList
检查第二个arraylist中是否存在该元素,并相应地将该元素添加到第三个列表中,如:
for(String temp: a1)
{
if(a2.contains(temp))
{
a3.add(1);
}
else
{
a3.add(0);
}
}
答案 3 :(得分: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)++;
答案 4 :(得分:0)
这样的事情:
ArrayList<Integer> a3 = new ArrayList<Integer>();
for (String v : a1) {
if (a2.contains(v)) {
a3.add(1);
} else {
a3.add(0);
}
}