有关List查找的问题

/**
	 * 高效率查找相同的元素或者不同的元 效率相对于最高的
	 * 
	 * @param list1
	 * @param list2
	 * @return
	 */
	public static List<String> getDiffrent(List<String> list1,
			List<String> list2) {
		Map<String, Integer> map = new HashMap<String, Integer>(list1.size()
				+ list2.size());
		List<String> diff = new ArrayList<String>();// 存放不同的元素
		List<String> diffs = new ArrayList<String>();// 存放相同的元素
		List<String> maxList = list1;
		List<String> 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<String, Integer> entry : map.entrySet()) {
			if (entry.getValue() == 1) {
				diff.add(entry.getKey());// //取出不同的元素
			}
			if (entry.getValue() >= 2) {
				diffs.add(entry.getKey());// 取出相同的元素;存放相同的元素
			}
		}

		return diff;
	}

	/**
	 * zhaohe 查找出两个List当中相同的元素
	 * 
	 * @param x
	 * @param y
	 * @return
	 */
	public static List<String> listEqual(List<String> x, List<String> y) {
		List<String> listString = null;
		try {
			listString = new ArrayList<String>();
			for (String x1 : x) {
				for (String y1 : y) {
					if (x1.equals(y1) || x1 == y1) {
						listString.add(y1);
					}
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return listString;
	}

	/**
	 * zhaohe 比较两个List<String>当中是否存在相同的数据 效率比较低
	 * 
	 * @param x
	 * @param y
	 * @return
	 */
	public static boolean compareToList(List<String> x, List<String> y) {
		boolean flag = false;
		for (String x1 : x) {
			for (String y1 : y) {
				if (x1.equals(y1) || x1 == y1) {
					flag = true;
					break;
				}
			}
		}
		return flag;
	}

	/**
	 * 查找一个List<String> 相同的元素
	 * 
	 * @return
	 */
	public static List<String> findSameListString(List<String> list) {
		List<String> diffList = new ArrayList<String>();
		Map<String, Integer> map = new HashMap<String, Integer>();
		for (String string : list) {
			Integer cc = map.get(string);
			if (cc != null) {
				map.put(string, ++cc);
				continue;
			}
			map.put(string, 1);
		}
		for (Map.Entry<String, Integer> entry : map.entrySet()) {
			if (entry.getValue() >= 2) {
				diffList.add(entry.getKey());// 取出相同的元素;存放相同的元素
			}
		}
		return diffList;

	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值