java 俩个集合取不同_两个list取不同值

package com.czp.test;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

public class TestList {

public static void main(String[] args) {

List list1 = new ArrayList();

List list2 = new ArrayList();

for (int i = 0; i 

list1.add("test"+i);

list2.add("test"+i*2);

}

getDiffrent(list1,list2);

getDiffrent3(list1,list2);

getDiffrent5(list1,list2);

getDiffrent4(list1,list2);

getDiffrent2(list1,list2);

//        getDiffrent3 total times 32271699

//        getDiffrent5 total times 12239545

//        getDiffrent4 total times 16786491

//        getDiffrent2 total times 2438731459

}

/**

* 获取两个List的不同元素

* @param list1

* @param list2

* @return

*/

private static List getDiffrent5(List list1, List list2) {

long st = System.nanoTime();

List diff = new ArrayList();

List maxList = list1;

List minList = list2;

if(list2.size()>list1.size())

{

maxList = list2;

minList = list1;

}

Map map = new HashMap(maxList.size());

for (String string : maxList) {

map.put(string, 1);

}

for (String string : minList) {

if(map.get(string)!=null)

{

map.put(string, 2);

continue;

}

diff.add(string);

}

for(Map.Entry entry:map.entrySet())

{

if(entry.getValue()==1)

{

diff.add(entry.getKey());

}

}

System.out.println("getDiffrent5 total times "+(System.nanoTime()-st));

return diff;

}

/**

* 获取两个List的不同元素

* @param list1

* @param list2

* @return

*/

private static List getDiffrent4(List list1, List list2) {

long st = System.nanoTime();

Map map = new HashMap(list1.size()+list2.size());

List diff = new ArrayList();

List maxList = list1;

List minList = list2;

if(list2.size()>list1.size())

{

maxList = list2;

minList = list1;

}

for (String string : maxList) {

map.put(string, 1);

}

for (String string : minList) {

Integer cc = map.get(string);

if(cc!=null)

{

map.put(string, ++cc);

continue;

}

map.put(string, 1);

}

for(Map.Entry entry:map.entrySet())

{

if(entry.getValue()==1)

{

diff.add(entry.getKey());

}

}

System.out.println("getDiffrent4 total times "+(System.nanoTime()-st));

return diff;

}

/**

* 获取两个List的不同元素

* @param list1

* @param list2

* @return

*/

private static List getDiffrent3(List list1, List list2) {

long st = System.nanoTime();

Map map = new HashMap(list1.size()+list2.size());

List diff = new ArrayList();

for (String string : list1) {

map.put(string, 1);

}

for (String string : list2) {

Integer cc = map.get(string);

if(cc!=null)

{

map.put(string, ++cc);

continue;

}

map.put(string, 1);

}

for(Map.Entry entry:map.entrySet())

{

if(entry.getValue()==1)

{

diff.add(entry.getKey());

}

}

System.out.println("getDiffrent3 total times "+(System.nanoTime()-st));

return diff;

}

/**

* 获取连个List的不同元素

* @param list1

* @param list2

* @return

*/

private static List getDiffrent2(List list1, List list2) {

long st = System.nanoTime();

list1.retainAll(list2);

System.out.println("getDiffrent2 total times "+(System.nanoTime()-st));

return list1;

}

/**

* 获取两个List的不同元素

* @param list1

* @param list2

* @return

*/

private static List getDiffrent(List list1, List list2) {

long st = System.nanoTime();

List diff = new ArrayList();

for(String str:list1)

{

if(!list2.contains(str))

{

diff.add(str);

}

}

System.out.println("getDiffrent total times "+(System.nanoTime()-st));

return diff;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值