Java遇到需要去重(去掉重复)的问题怎么办

Java遇到需要去重(去掉重复)的问题怎么办

  • JAVA去重
    • 去掉在List中对象属性重复的对象
      • 应用
    • 去除List中的重复元素

JAVA去重

去掉在List中对象属性重复的对象

/**
 * 去重
 * 需要去掉学生中分数相同的
 */
 //需要去重的List
List ListStudents= new ArrayList();
 //创建一个set
Set set = new HashSet(); 
//记录set的大小
int nowsize = set.size();
//用存放去重后的对象
List listTemp = new ArrayList();
//循环
for(int i=0;i

应用

  • 可用于实际项目下拉框,需要查询数据库的数据时,如果出现重复的数据,使用该方法去重。
    Java遇到需要去重(去掉重复)的问题怎么办_第1张图片

去除List中的重复元素

		// 第一种:通过创建新的集合来存储不重复的元素
		//需要去重的List
		List list1 = new ArrayList();
		//新的List
		List list2 = new ArrayList();
		for (String in : list1) {
			if (!list2.contains(in)) {
				list2.add(in);
			}
		}
		System.out.println(list2);
 
		// 第二种:把集合元素先删除,后添加不重复的元素
		//需要去重的List
		List list1 = new ArrayList();
		for (int i = 0; i < list1.size(); i++) {
			String in = list1.remove(i);
			if (!list1.contains(in)) {
				list.add(i, in);
			} else {
				i--;
			}
		}
		System.out.println(list1);
 
		// 第三种:利用set集合自动去重的特性
		//需要去重的List
		List list1 = new ArrayList();
		System.out.println(list1);
		Set set = new HashSet(list);
		//新的List
		List list2 = new ArrayList(set);
		System.out.println(list2);

		// 第四种:利用treeSet集合自动去重的特性
		//需要去重的List
		List list1 = new ArrayList();
		System.out.println(list1);
		TreeSet treeSet = new TreeSet(list);
		//新的List
		List list2 = new ArrayList(treeSet);
		System.out.println(list2);
		//treeSet的默认排序的升序,根据实际情况选择排序方式,降序可使用reverse

你可能感兴趣的:(Java)