去重复数据(JAVA)

public class RemoveDu {

	/**
	 *By过忍
	 */
	public static void main(String[] args) {
		//测试数据
		ArrayList<String> list = new ArrayList<String>();
		Random random = new Random();
		for(int i = 0; i<10000; i++){
			list.add(""+random.nextInt(20));
		}
		
		//方法类
		ReDu reDu= new ReDu();
		
		//方法1
		long t1=System.currentTimeMillis();
		reDu.print(reDu.remove1(list));
		long t2=System.currentTimeMillis();
		System.out.println("方法1所用时间:"+(t2-t1)+"毫秒");
		
		//方法2
		t1=System.currentTimeMillis();
		reDu.print(reDu.remove2(list));
		t2=System.currentTimeMillis();
		System.out.println("方法2所用时间:"+(t2-t1)+"毫秒");
	}
}

//去掉重复的方法
 class ReDu{
		//方法1
		public List<String> remove1(List<String> list1)
		{
		    HashSet<String> h=new HashSet<String>(list1);
		    list1.clear();
		    list1.addAll(h);
		    List<String> list2=new ArrayList<String>();
		    list2=list1;
		    return list2;
		}
		
		//方法2
		public List<String> remove2(List<String> list2){
			List<String> list=new ArrayList<String>();
			for(String i: list2){
				if(Collections.frequency(list2, i) < 2) list.add(i);
				}
			return list;
		}
		
		//输出
		public void print(List<String> list){
			System.out.print("10000个随机在[1,20]的数,排除重复后的数据: ");
			for(int i = 0;i<list.size();i++){
				System.out.print(list.get(i)+",");
			}
		}
	}

输出结果:

10000个随机在[1,20]的数,排除重复后的数据: 3,2,1,0,7,6,5,4,9,8,19,17,18,15,16,13,14,11,12,10,方法1所用时间:35毫秒
10000个随机在[1,20]的数,排除重复后的数据: 3,2,1,0,7,6,5,4,9,8,19,17,18,15,16,13,14,11,12,10,方法2所用时间:3毫秒

Java中,有多种方法可以去除List中的重复数据。以下是三种常见的方法: 方法一:使用双重循环遍历List,逐个比较元素并删除重复的元素。这种方法会改变原始List的顺序。 ```java public static List removeDuplicate(List list) { for (int i = 0; i < list.size() - 1; i++) { for (int j = list.size() - 1; j > i; j--) { if (list.get(j).equals(list.get(i))) { list.remove(j); } } } return list; } ``` 方法二:使用HashSet来去除重复元素,并保持原始List的顺序。首先将List中的元素逐个添加到HashSet中,HashSet会自动去除重复元素。然后将HashSet中的元素重新添加到一个新的List中。 ```java public static void removeDuplicateWithOrder(List list) { Set set = new HashSet(); List newList = new ArrayList(); for (Iterator iter = list.iterator(); iter.hasNext();) { Object element = iter.next(); if (set.add(element)) newList.add(element); } list.clear(); list.addAll(newList); System.out.println("remove duplicate " + list); } ``` 方法三:使用一个临时的List来存储不重复的元素。遍历原始List,如果临时List中不包含当前元素,则将其添加到临时List中。 ```java public static List removeDuplicate(List list) { List listTemp = new ArrayList(); for (int i = 0; i < list.size(); i++) { if (!listTemp.contains(list.get(i))) { listTemp.add(list.get(i)); } } return listTemp; } ``` 以上是三种常见的去除List中重复数据的方法,你可以根据具体需求选择适合的方法来使用。 #### 引用[.reference_title] - *1* *2* *3* [Java中List集合去除重复数据的六种方法](https://blog.csdn.net/gb4215287/article/details/122599183)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值