GP Coder

Trang chia sẻ kiến thức lập trình Java

  • Java Core
    • Basic Java
    • OOP
    • Exception Handling
    • Multi-Thread
    • Java I/O
    • Networking
    • Reflection
    • Collection
    • Java 8
  • Design pattern
    • Creational Pattern
    • Structuaral Pattern
    • Behavior Pattern
  • Web Service
    • SOAP
    • REST
  • JPA
  • Java library
    • Report
    • Json
    • Unit Test
  • Message Queue
    • ActiveMQ
    • RabbitMQ
  • All
Trang chủ Java Core Collection Loại bỏ các phần tử trùng trong một ArrayList như thế nào?

Loại bỏ các phần tử trùng trong một ArrayList như thế nào?

Đăng vào 28/11/2017 . Được đăng bởi GP Coder . 23468 Lượt xem . Toàn màn hình

ArrayList là một trong những Collection được sử dụng nhiều nhất trong java. Nó cung cấp cho sự linh hoạt của việc thêm nhiều phần tử null, phần tử trùng lặp và cũng duy trì thứ tự chèn của các phần tử. Đôi khi, bạn gặp yêu cầu mà bạn phải loại bỏ các phần tử trùng lặp từ ArrayList đã xây dựng xong. Trong bài này, chúng ta sẽ cùng thảo luận các phương pháp để loại bỏ các phần tử trùng lặp từ một ArrayList.

Nội dung

  • 1 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng vòng lặp for
  • 2 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng HashSet
  • 3 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng LinkedHashSet

Loại bỏ phần tử trùng lặp trong ArrayList sử dụng vòng lặp for

Trong phương pháp này, tôi tạo một ArrayList khác để lưu giữ các phần tử không trùng. Sử dụng một vòng lặp for để duyệt qua các phần tử và sử dụng phương thức contains() của lớp ArrayList để kiểm tra phần tử đã tồn tại trong danh sách mới hay chưa: nếu chưa tồn tại thì thêm nó vào danh sách mới, nếu đã tồn tại thì duyệt qua phần tử kế tiếp. Đến cuối cùng ta có được một danh sách không chứa phần tử trùng.

Ví dụ:


package com.gpcoder.collection.list.arraylist;

import java.util.ArrayList;
import java.util.List;

public class RemoveDuplicateInArrayList1 {
	public static void main(String[] args) {
		// Constructing An ArrayList
		List<String> listWithDuplicateElements = new ArrayList<String>();
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("J2EE");
		listWithDuplicateElements.add("JSP");
		listWithDuplicateElements.add("SERVLETS");
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("STRUTS");
		listWithDuplicateElements.add("JSP");

		// Printing listWithDuplicateElements
		System.out.println("ArrayList With Duplicate Elements :");
		System.out.println(listWithDuplicateElements);

		// Constructing Another ArrayList
		List<String> listWithoutDuplicateElements = new ArrayList<String>();
		for (String element : listWithDuplicateElements) {
			// Check if element not exist in list, perform add element to list
			if (!listWithoutDuplicateElements.contains(element)) {
				listWithoutDuplicateElements.add(element);
			}
		}

		// Printing listWithoutDuplicateElements
		System.out.println("\nArrayList After Removing Duplicate Elements :");
		System.out.println(listWithoutDuplicateElements);
	}
}

Kết quả thực thi chương trình trên:

ArrayList With Duplicate Elements :
[JAVA, J2EE, JSP, SERVLETS, JAVA, STRUTS, JSP]

ArrayList After Removing Duplicate Elements :
[JAVA, J2EE, JSP, SERVLETS, STRUTS]

Loại bỏ phần tử trùng lặp trong ArrayList sử dụng HashSet

Trong phương pháp này, tôi sử dụng HashSet để loại bỏ các phần tử trùng lặp từ một ArrayList. Như bạn đã biết, HashSet không cho phép các phần tử trùng lặp. Tôi sử dụng thuộc tính này của HashSet để loại bỏ các phần tử trùng lặp từ ArrayList đã xây dựng xong. Tuy nhiên, có một bất lợi của phương pháp này. Nghĩa là, nó xóa thứ tự chèn của các phần tử ArrayList. Điều đó có nghĩa là, sau khi gỡ bỏ các phần tử trùng lặp, các phần tử sẽ không còn đúng thứ tự chèn.

Ví dụ:


package com.gpcoder.collection.list.arraylist;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

public class RemoveDuplicateInArrayList2 {
	public static void main(String[] args) {
		// Constructing An ArrayList
		List<String> listWithDuplicateElements = new ArrayList<String>();
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("J2EE");
		listWithDuplicateElements.add("JSP");
		listWithDuplicateElements.add("SERVLETS");
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("STRUTS");
		listWithDuplicateElements.add("JSP");

		// Printing listWithDuplicateElements
		System.out.println("ArrayList With Duplicate Elements :");
		System.out.println(listWithDuplicateElements);

		// Constructing HashSet using listWithDuplicateElements
		Set<String> set = new HashSet<String>(listWithDuplicateElements);

		// Constructing listWithoutDuplicateElements using set
		List<String> listWithoutDuplicateElements = new ArrayList<String>(set);

		// Printing listWithoutDuplicateElements
		System.out.println("\nArrayList After Removing Duplicate Elements :");
		System.out.println(listWithoutDuplicateElements);
	}
}

Kết quả thực thi chương trình trên:

ArrayList With Duplicate Elements :
[JAVA, J2EE, JSP, SERVLETS, JAVA, STRUTS, JSP]

ArrayList After Removing Duplicate Elements :
[JAVA, SERVLETS, JSP, J2EE, STRUTS]

Bạn có thể thấy kết quả của ví dụ trên: các phần tử được xáo trộn sau khi loại bỏ các phần tử trùng. Chúng không còn đúng theo thứ tự chèn. Nếu bạn muốn thứ tự chèn của các phần tử được duy trì sau khi loại bỏ các phần tử trùng lặp, thì phương pháp này không được khuyến khích. Có một phương pháp tồn tại mà không làm thay đổi thứ tự chèn của các phần tử ngay cả sau khi loại bỏ các phần tử trùng lặp. Đó là sử dụng LinkedHashSet.

Loại bỏ phần tử trùng lặp trong ArrayList sử dụng LinkedHashSet

Trong phương pháp này, tôi sử dụng LinkedHashSet để loại bỏ các phần tử trùng lặp từ ArrayList. Như bạn biết rằng, LinkedHashSet không cho phép các phần tử trùng lặp và duy trì thứ tự chèn của các phần tử. Cả hai thuộc tính này của LinkedHashSet được sử dụng ở đây để loại bỏ các phần tử trùng lặp khỏi ArrayList và cũng duy trì trình tự chèn của các phần tử. Xem ví dụ dưới đây:


package com.gpcoder.collection.list.arraylist;

import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;

public class RemoveDuplicateInArrayList3 {
	public static void main(String[] args) {
		// Constructing An ArrayList
		List<String> listWithDuplicateElements = new ArrayList<String>();
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("J2EE");
		listWithDuplicateElements.add("JSP");
		listWithDuplicateElements.add("SERVLETS");
		listWithDuplicateElements.add("JAVA");
		listWithDuplicateElements.add("STRUTS");
		listWithDuplicateElements.add("JSP");

		// Printing listWithDuplicateElements
		System.out.println("ArrayList With Duplicate Elements :");
		System.out.println(listWithDuplicateElements);

		// Constructing LinkedHashSet using listWithDuplicateElements
		Set<String> set = new LinkedHashSet<String>(listWithDuplicateElements);

		// Constructing listWithoutDuplicateElements using set
		List<String> listWithoutDuplicateElements = new ArrayList<String>(set);

		// Printing listWithoutDuplicateElements
		System.out.println("\nArrayList After Removing Duplicate Elements :");
		System.out.println(listWithoutDuplicateElements);
	}
}

Kết quả thực thi chương trình trên:

ArrayList With Duplicate Elements :
[JAVA, J2EE, JSP, SERVLETS, JAVA, STRUTS, JSP]

ArrayList After Removing Duplicate Elements :
[JAVA, J2EE, JSP, SERVLETS, STRUTS]

Trên đây là 3 phương pháp thường được sử dụng để loại bỏ các phần tử trùng lặp trong ArrayList. Bạn có thể sử dụng một trong ba phương pháp trên để áp dụng vào chương trình của mình. Trong thực tế, tôi thường sử dụng phương pháp 2 (dùng HashSet) nếu không cần quan tâm đến thứ tự của các phần tử hoặc sử dụng phương pháp 3 (dùng LinkedHashSet) nếu cần giữ đúng thứ tự của phần tử sau khi loại bỏ phần tử trùng.

Trong java 8, chúng ta có thêm một số cách khác để loại bỏ phần tử trùng. Các bạn hãy xem thêm ở bài viết: Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?

3.5
24
Nếu bạn thấy hay thì hãy chia sẻ bài viết cho mọi người nhé! Và Donate tác giả

Shares

Chuyên mục: Collection Được gắn thẻ: Collection, How to

Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Chuyển đổi từ HashMap sang ArrayList

Có thể bạn muốn xem:

  • LinkedHashSet trong Java hoạt động như thế nào? (19/11/2017)
  • Chuyển đổi Array sang ArrayList và ngược lại (30/11/2017)
  • HashSet trong Java hoạt động như thế nào? (19/11/2017)
  • So sánh ArrayList và Vector trong Java (21/11/2017)
  • Queue và PriorityQueue trong Java (22/11/2017)

Bình luận

bình luận

Tìm kiếm

Bài viết mới

  • Clean code 13/01/2024
  • Giới thiệu CloudAMQP – Một RabbitMQ server trên Cloud 02/10/2020
  • Kết nối RabbitMQ sử dụng Web STOMP Plugin 19/06/2020
  • Sử dụng publisher confirm trong RabbitMQ 16/06/2020
  • Sử dụng Dead Letter Exchange trong RabbitMQ 13/06/2020

Xem nhiều

  • Hướng dẫn Java Design Pattern – Factory Method (98065 lượt xem)
  • Hướng dẫn Java Design Pattern – Singleton (97703 lượt xem)
  • Giới thiệu Design Patterns (87776 lượt xem)
  • Lập trình đa luồng trong Java (Java Multi-threading) (86443 lượt xem)
  • Giới thiệu về Stream API trong Java 8 (83840 lượt xem)

Nội dung bài viết

  • 1 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng vòng lặp for
  • 2 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng HashSet
  • 3 Loại bỏ phần tử trùng lặp trong ArrayList sử dụng LinkedHashSet

Lưu trữ

Thẻ đánh dấu

Annotation Authentication Basic Java Behavior Pattern Collection Creational Design Pattern Cấu trúc điều khiển Database Dependency Injection Design pattern Eclipse Exception Executor Service Google Guice Gson Hibernate How to Interceptor IO Jackson Java 8 Java Core JDBC JDK Jersey JMS JPA json JUnit JWT Message Queue Mockito Multithreading OOP PowerMockito RabbitMQ Reflection Report REST SOAP Structuaral Pattern Swagger Thread Pool Unit Test Webservice

Liên kết

  • Clean Code
  • JavaTpoint
  • Refactoring Guru
  • Source Making
  • TutorialsPoint
  • W3Schools Online Web Tutorials

Giới thiệu

GP Coder là trang web cá nhân, được thành lập với mục đích lưu trữ, chia sẽ kiến thức đã học và làm việc của tôi. Các bài viết trên trang này chủ yếu về ngôn ngữ Java và các công nghệ có liên quan đến Java như: Spring, JSF, Web Services, Unit Test, Hibernate, SQL, ...
Hi vọng góp được chút ít công sức cho sự phát triển cộng đồng Coder Việt.

Donate tác giả

Tìm kiếm các bài viết của GP Coder với Google Search

Liên hệ

Các bạn có thể liên hệ với tôi thông qua:
  • Trang liên hệ
  • Linkedin: gpcoder
  • Email: contact@gpcoder.com
  • Skype: ptgiang56it

Follow me

Copyright 2025 © GP Coder · All Rights Reserved · Giới thiệu · Chính sách · Điều khoản · Liên hệ ·

Share

Blogger
Delicious
Digg
Email
Facebook
Facebook messenger
Flipboard
Google
Hacker News
Line
LinkedIn
Mastodon
Mix
Odnoklassniki
PDF
Pinterest
Pocket
Print
Reddit
Renren
Short link
SMS
Skype
Telegram
Tumblr
Twitter
VKontakte
wechat
Weibo
WhatsApp
X
Xing
Yahoo! Mail

Copy short link

Copy link