比较两个list里是否有相同的元素

JavaScript011

比较两个list里是否有相同的元素,第1张

首先这里需要确定一下集合相等的定义,我们应该是认为两个集合的元素完全一致则相等。那么判断可以这样做:

第一步:判断两个list集合的元素个数是否相等。如果不相等则两个list集合也不相等,判断结束,如果相等则进入第二步判断

第二步:判断list1的元素是否全部在list2中。遍历list1,取出list1中的元素,依次去list2中比较是否list2也存在这个元素。如果有任何一个list1中的元素在list2中不存在,则两个list集合不相等,如果全部存在则两个list集合相等。

这里需要说明一点,因为第一步中已经判断list1和list2的元素个数是相等的,所以第二步中如果list1的元素全部在list2中,则可以证明list1与list2相等。不需要再遍历list2中的元素,去list1中判断是否存在。

以下是上诉过程的Java代码例子:

public boolean equalList(List list1, List list2) {

if (list1.size() != list2.size())

return false

使用java判断两个bailist中的对象是否完全一致的代码如下:

public class Test {public static void main(String[] args) 

{List<Integer>a = Arrays.asList(1, 2, 3, 4)

List<Integer>b = Arrays.asList(4, 3, 2, 1)System.out.println(compare(a, b))

public static <T extends Comparable<T>>boolean compare(List<T>a, List<T>b) {if (a.size() != b.size())

return falseCollections.sort(a)Collections.sort(b)for (int i = 0i <a.size()i++) {if (!a.get(i).equals(b.get(i)))return false}return true}}

扩展资料:

在编程语言中List 是标准类库中的一个类,可以简单视之为双向链表,以线性列的方式管理物件集合。list 的特色是在集合的任何位置增加或删除元素都很快,但是不支持随机存取。list 是类库提供的众多容器(container)之一,除此之外还有vector、set、map、…等等。

list 以模板方式实现(即泛型),可以处理任意型别的变量,包括使用者自定义的资料型态例如:它可以是一个放置整数(int)型态的 list、也可以是放置字串(char 或 string)型态的 list、或者放置使用者自定类别(user-defined class)的 list。

参考资料来源:百度百科-list

int count=0

for(int i=0i<list1.size()i++){

for(int j=0j<list2.size()j++){

//判断值是否相同

if(list1.get(i).equal(list2.get(j))){

count=count+1//相同count加一

}

}

}

System.out.println("相同值的个数="+count)