SlideShare a Scribd company logo
V
Tổng quan về cấu trúc dữ
liệu và giải thuật
Cấu trúc dữ liệu là gì?
Giải thuật là gì?
Cài đặt môi trường
Giải thuật tiệm cận
Giải thuật tham lam
Giải thuật chia để trị
Giải thuật qui hoạch động
Cấu trúc dữ liệu mảng
Cấu trúc dữ liệu Linked
List
Cấu trúc dữ Doubly Linked
List
Cấu trúc dữ Circular Linked
List
Cấu trúc dữ liệu ngăn xếp -
Stack
Cấu trúc dữ hàng dợi -
Queue
Cấu Trúc Dữ Liệu & Giải
Thuật
Giải Thuật
Cấu Trúc Dữ Liệu Mảng
Danh sách liên kết -
Linked list
Ngăn Xếp & Hàng Đợi
Một Số Giải Thuật Tìm
Kiếm
 Cấu trúc dữ liệu mảng Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List) 
Cấu trúc dữ liệu danh sách liên kết (Linked List)
Nội dung chính
Danh sách liên kết (Linked List) là gì?
Biểu diễn danh sách liên kết (Linked List)
Các loại Danh sách liên kết (Linked List)
Các hoạt động cơ bản trên Danh sách liên kết
Hoạt động chèn trong Danh sách liên kết
Hoạt động xóa trong Danh sách liên kết
Hoạt động đảo ngược Danh sách liên kết
Danh sách liên kết (Linked List) là gì?
Một danh sách liên kết (Linked List) là một dãy các cấu trúc dữ liệu bao gồm một nhóm các nút (node)
được kết nối với nhau thông qua các liên kết (link) tạo thành một chuỗi. Mỗi nút gồm dữ liệu ở nút đó và
tham chiếu đến nút kế tiếp trong chuỗi.
Danh sách liên kết là cấu trúc dữ liệu được sử dụng phổ biến thứ hai sau mảng. Dưới đây là các khái niệm
cơ bản liên quan tới Danh sách liên kết:
Link (liên kết): mỗi link của một Danh sách liên kết có thể lưu giữ một dữ liệu được gọi là một phần tử.
Next: Mỗi liên kết của một Danh sách liên kết chứa một link tới next link được gọi là Next.
First: một Danh sách liên kết bao gồm các link kết nối tới first link được gọi là First.
Recent Updates
Xuất dữ liệu ra màn hình console trong
Java
Cài đặt môi trường Java
Java Swing - Bài tập quản lý sinh viên
trong java
LinkedList trong java
ArrayList trong java
Bài tập java có lời giải
Xác thực dữ liệu (Data Validation) trong
Excel
Sắp xếp dữ liệu trong Excel
Lọc dữ liệu (Data Filter) trong Excel
Header và Footer trong Excel
Màu văn bản và màu nền (background)
trong Excel
Căn chỉnh văn bản trong Excel
Sắp Tết 2026 Rồi! - Còn bao nhiêu ngày
nữa là đến tết 2026?
VietTuts on facebook
Home Java Servlet JSP Struts2 Hibernate Spring MyBatis Java WS C C++ C# Python PHP Excel VBA Web SQL Misc
Học Lập Trình Online
Học Lập Trình Online …
…
5.672 người theo dõi
5.672 người theo dõi
Theo dõi Trang Chia sẻ
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 1/7
Tìm kiếm tuyến tính - Linear
Search
Tìm kiếm nhị phân - Binary
Search
Tìm kiếm nội suy -
Interpolation Search
Cấu trúc dữ liệu Hash Table
Giải thuật sắp xếp
Sắp xếp nổi bọt - Bubble
Sort
Sắp xếp chèn - Insertion
Sort
Sắp xếp chọn - Selection
Sort
Sắp xếp trộn - Merge Sort
Sắp xếp nhanh - Quick Sort
Giải thuật Shell Sort
Giải thuật quay lui - Back
Tracking
Cấu trúc dữ liệu đồ thị
Tìm kiếm theo chiều sâu -
Depth First Search
Tìm kiếm theo chiều sâu -
Breadth First Search
Một Số Giải Thuật Sắp
Xếp
Cấu Trúc Dữ Liệu Đồ Thị
(Graph)
Biểu diễn danh sách liên kết (Linked List)
Danh sách liên kết có thể được biểu diễn như là một chuỗi các nút (node). Mỗi nút sẽ trỏ tới nút kế tiếp.
Dưới đây là một số điểm cần nhớ về Danh sách liên kết:
Danh sách liên kết chứa một phần tử link thì được gọi là First.
Mỗi link mang một trường dữ liệu và một trường link được gọi là Next.
Mỗi link được liên kết với link kế tiếp bởi sử dụng link kế tiếp của nó.
Link cuối cùng mang một link là null để đánh dấu điểm cuối của danh sách.
Các loại Danh sách liên kết (Linked List)
Dưới đây là các loại Danh sách liên kết (Linked List) đa dạng:
Danh sách liên kết đơn (Simple Linked List): chỉ duyệt các phần tử theo chiều về trước.
Danh sách liên kết đôi (Doubly Linked List): các phần tử có thể được duyệt theo chiều về trước hoặc về
sau.
Danh sách liên kết vòng (Circular Linked List): phần tử cuối cùng chứa link của phần tử đầu tiên như là
next và phần tử đầu tiên có link tới phần tử cuối cùng như là prev.
Các hoạt động cơ bản trên Danh sách liên kết
Dưới đây là một số hoạt động cơ bản có thể được thực hiện bởi một danh sách liên kết:
Hoạt động chèn: thêm một phần tử vào đầu danh sách liên kết.
Hoạt động xóa (phần tử đầu): xóa một phần tử tại đầu danh sách liên kết.
Hiển thị: hiển thị toàn bộ danh sách.
Hoạt động tìm kiếm: tìm kiếm phần tử bởi sử dụng khóa (key) đã cung cấp.
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 2/7
Hoạt động xóa (bởi sử dụng khóa): xóa một phần tử bởi sử dụng khóa (key) đã cung cấp.
Hoạt động chèn trong Danh sách liên kết
Việc thêm một nút mới vào trong danh sách liên kết không chỉ là một hoạt động thêm đơn giản như trong
các cấu trúc dữ liệu khác (bởi vì chúng ta có dữ liệu và có link). Chúng ta sẽ tìm hiểu thông qua sơ đồ
dưới đây. Đầu tiên, tạo một nút bởi sử dụng cùng cấu trúc và tìm vị trí để chèn nút này.
Giả sử chúng ta cần chèn một nút B vào giữa nút A (nút trái) và C (nút phải). Do đó: B.next trỏ tới C.
Output:
NewNode.next −> RightNode;
Hình minh họa như sau:
Bây giờ, next của nút bên trái sẽ trở tới nút mới.
Output:
LeftNode.next −> NewNode;
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 3/7
Quá trình trên sẽ đặt nút mới vào giữa hai nút. Khi đó danh sách mới sẽ trông như sau:
Các bước tương tự sẽ được thực hiện nếu chèn nút vào đầu danh sách liên kết. Trong khi đặt một nút vào
vị trí cuối của danh sách, thìnút thứ hai tính từ nút cuối cùng của danh sách sẽ trỏ tới nút mới và nút mới
sẽ trỏ tới NULL.
Hoạt động xóa trong Danh sách liên kết
Hoạt động xóa trong Danh sách liên kết cũng phức tạp hơn trong cấu trúc dữ liệu khác. Đầu tiên chúng ta
cần định vị nút cần xóa bởi sử dụng các giải thuật tìm kiếm.
Bây giờ, nút bên trái (prev) của nút cần xóa nên trỏ tới nút kế tiếp (next) của nút cần xóa.
Output:
LeftNode.next −> TargetNode.next;
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 4/7
Quá trình này sẽ xóa link trỏ tới nút cần xóa. Bây giờ chúng ta sẽ xóa những gì mà nút cần xóa đang trỏ
tới.
Output:
TargetNode.next −> NULL;
Nếu bạn cần sử dụng nút đã bị xóa này thì bạn có thể giữ chúng trong bộ nhớ, nếu không bạn có thể xóa
hoàn toàn hẳn nó khỏi bộ nhớ.
Hoạt động đảo ngược Danh sách liên kết
Với hoạt động này, bạn cần phải cẩn thận. Chúng ta cần làm cho nút đầu (head) trỏ tới nút cuối cùng và
đảo ngược toàn bộ danh sách liên kết.
Đầu tiên, chúng ta duyệt tới phần cuối của danh sách. Nút này sẽ trỏ tới NULL. Bây giờ điều cần làm là
làm cho nút cuối này trỏ tới nút phía trước của nó.
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 5/7
 Cấu trúc dữ liệu mảng Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List) 
Chúng ta phải đảm bảo rằng nút cuối cùng này sẽ không bị thất lạc, do đó chúng ta sẽ sử dụng một số nút
tạm (temp node – giống như các biến tạm trung gian để lưu giữ giá trị). Tiếp theo, chúng ta sẽ làm cho
từng nút bên trái sẽ trỏ tới nút trái của chúng.
Sau đó, nút đầu tiên sau nút head sẽ trỏ tới NULL.
Chúng ta sẽ làm cho nút head trỏ tới nút đầu tiên mới bởi sử dụng các nút tạm.
Bây giờ danh sách liên kết đã bị đảo ngược.
Danh Sách Bài Học Bài Tập Có Lời Giải Câu Hỏi Phỏng Vấn
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 6/7
Học Java | Hibernate | Spring
Học Excel | Excel VBA
Học Servlet | JSP | Struts2
Học C | C++ | C#
Học Python
Học SQL
Bài tập Java
Bài tập C
Bài tập C++
Bài tập C#
Bài tập Python
Ví dụ Excel VBA
201 câu hỏi phỏng vấn java
25 câu hỏi phỏng vấn servlet
75 câu hỏi phỏng vấn jsp
52 câu hỏi phỏng vấn Hibernate
70 câu hỏi phỏng vấn Spring
57 câu hỏi phỏng vấn SQL
Copyright © 2016 VietTuts.Vn all rights reserved. | Liên hệ | Chính sách - riêng tư | sitemap.html | sitemap_index.xml
18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts
https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 7/7

More Related Content

PDF
Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List) - VietTuts.pdf
PDF
Cấu trúc dữ liệu danh sách liên kết vòng (Circular Linked List) - VietTuts.pdf
PPTX
Danh sách liên kết là 1 cấu trúc dữ liệu được sử dụng để lưu trữ 1 tập hợp cá...
PPT
C3 danh sachlienket
PDF
C5 danhsachlienket
PPTX
Cấu Trúc Dữ Liệu_Baigiang4_Danh sách liên kết.pptx
PDF
Bai5 dsachlket
PDF
ctdl&gt 05-list_kep
Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List) - VietTuts.pdf
Cấu trúc dữ liệu danh sách liên kết vòng (Circular Linked List) - VietTuts.pdf
Danh sách liên kết là 1 cấu trúc dữ liệu được sử dụng để lưu trữ 1 tập hợp cá...
C3 danh sachlienket
C5 danhsachlienket
Cấu Trúc Dữ Liệu_Baigiang4_Danh sách liên kết.pptx
Bai5 dsachlket
ctdl&gt 05-list_kep

Similar to Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts.pdf (20)

PDF
Cau truc dl_va_giai_thuat_bai1[1] - copy
PDF
CHƯƠNG 3.pdf
PPT
Cấu trúc dữ liệu động
PDF
cau-truc-du-lieu-va-giai-thuat_pham-the-bao_slides---danh-sach.pdf
PDF
danh sach lien ket trong ngon ngu lap trinh C.pdf
PDF
ctdl&gt 04-list_don
PDF
Bài 7: Danh sách liên kết (LINKED LIST) và tập hợp (SET) - Giáo trình FPT
PDF
Cấu trúc dữ liệu kiểu danh sách liên kết
PPT
Chg2 danh sach
PDF
Cấu trúc dữ liệu cơ bản 2
PPTX
CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT.pptx
PDF
02 stack queue
PDF
Baigiang ctdl
PDF
Chuong 4 danh sach lien ket
PDF
Cấu trúc dữ liệu đồ thị (Graph) - VietTuts.pdf
PDF
Cấu truc-dữ-liệu-va-thuật-giải-1
PPTX
Stack & queue
DOC
Bài tập CTDL và GT 3
PPT
BáO CáO Lý ThuyếT Java
PDF
bao-cao-nghien-cuu-va-tim-hieu-ve-neo4j.pdf
Cau truc dl_va_giai_thuat_bai1[1] - copy
CHƯƠNG 3.pdf
Cấu trúc dữ liệu động
cau-truc-du-lieu-va-giai-thuat_pham-the-bao_slides---danh-sach.pdf
danh sach lien ket trong ngon ngu lap trinh C.pdf
ctdl&gt 04-list_don
Bài 7: Danh sách liên kết (LINKED LIST) và tập hợp (SET) - Giáo trình FPT
Cấu trúc dữ liệu kiểu danh sách liên kết
Chg2 danh sach
Cấu trúc dữ liệu cơ bản 2
CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT.pptx
02 stack queue
Baigiang ctdl
Chuong 4 danh sach lien ket
Cấu trúc dữ liệu đồ thị (Graph) - VietTuts.pdf
Cấu truc-dữ-liệu-va-thuật-giải-1
Stack & queue
Bài tập CTDL và GT 3
BáO CáO Lý ThuyếT Java
bao-cao-nghien-cuu-va-tim-hieu-ve-neo4j.pdf
Ad

Recently uploaded (20)

PDF
Vision - Language - Model-- - Ebook.pdf
PDF
BÀI TẬP TEST BỔ TRỢ THEO TỪNG UNIT - TIẾNG ANH 10 GLOBAL SUCCESS - CẢ NĂM (30...
PPTX
Xuất huyết tiêu hoá Đại học Y Hà Nội.pptx
PDF
BÀI TẬP BỔ TRỢ FRIENDS PLUS 9 - BÀI TẬP TRẮC NGHIỆM, TỰ LUẬN - CẢ NĂM (BÁM SÁ...
DOCX
BÀI TIỂU LUẬN HẾT HỌC PHẦN TỔ CHỨC HOẠT ĐỘNG TRẢI NGHIỆM,HƯỚNG NGHIỆP Ở TRƯỜN...
PPTX
Bài giảng Quần xã sinh vật sinh học lớp 8
DOCX
xin loi vi da den bai hoc cuo bd thnnn 2
DOCX
Set menu 3 món rất hay và hiện đại dành cho người
PPTX
Chuong1,2-Phuongphapnghiencuukhoahoc.pptx
DOCX
2024-2025 HSG HÓA 12 CỤM LẦN 3 - Hải Dương - đề.docx
PPTX
Bộ Giáo Trình Chuẩn YCT 2 12 --第十二YCT2课.pptx
PPT
chương 1 cơ sở văn hóa Việt Nam - định nghĩa - đặc trưng - chức năng
PDF
BÀI TẬP BỔ TRỢ FRIENDS PLUS 9 - BÀI TẬP TRẮC NGHIỆM, TỰ LUẬN - CẢ NĂM (BÁM SÁ...
DOCX
Bài tập trăc nghiệm vận tốc. tốc độ trong chuyển động thẳng
PDF
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 8 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
DOC
Chương 1 Tính tương đổi của chuyển động.doc
PDF
PHÁT TRIỂN NĂNG LỰC KHÁM PHÁ TỰ NHIÊN CHO HỌC SINH TRONG DẠY HỌC CHỦ ĐỀ VẬT S...
PPTX
TIẾT 11. BÀI 32 DINH DƯỠNG VÀ TIÊU HÓA Ở NGƯỜI.pptx
PPTX
Bài giảng Quần thể sinh vật Sinh học lớp 8
DOCX
Luận văn group-Bài tiểu luận Ý thức - Giấc mơ.docx
Vision - Language - Model-- - Ebook.pdf
BÀI TẬP TEST BỔ TRỢ THEO TỪNG UNIT - TIẾNG ANH 10 GLOBAL SUCCESS - CẢ NĂM (30...
Xuất huyết tiêu hoá Đại học Y Hà Nội.pptx
BÀI TẬP BỔ TRỢ FRIENDS PLUS 9 - BÀI TẬP TRẮC NGHIỆM, TỰ LUẬN - CẢ NĂM (BÁM SÁ...
BÀI TIỂU LUẬN HẾT HỌC PHẦN TỔ CHỨC HOẠT ĐỘNG TRẢI NGHIỆM,HƯỚNG NGHIỆP Ở TRƯỜN...
Bài giảng Quần xã sinh vật sinh học lớp 8
xin loi vi da den bai hoc cuo bd thnnn 2
Set menu 3 món rất hay và hiện đại dành cho người
Chuong1,2-Phuongphapnghiencuukhoahoc.pptx
2024-2025 HSG HÓA 12 CỤM LẦN 3 - Hải Dương - đề.docx
Bộ Giáo Trình Chuẩn YCT 2 12 --第十二YCT2课.pptx
chương 1 cơ sở văn hóa Việt Nam - định nghĩa - đặc trưng - chức năng
BÀI TẬP BỔ TRỢ FRIENDS PLUS 9 - BÀI TẬP TRẮC NGHIỆM, TỰ LUẬN - CẢ NĂM (BÁM SÁ...
Bài tập trăc nghiệm vận tốc. tốc độ trong chuyển động thẳng
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 8 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
Chương 1 Tính tương đổi của chuyển động.doc
PHÁT TRIỂN NĂNG LỰC KHÁM PHÁ TỰ NHIÊN CHO HỌC SINH TRONG DẠY HỌC CHỦ ĐỀ VẬT S...
TIẾT 11. BÀI 32 DINH DƯỠNG VÀ TIÊU HÓA Ở NGƯỜI.pptx
Bài giảng Quần thể sinh vật Sinh học lớp 8
Luận văn group-Bài tiểu luận Ý thức - Giấc mơ.docx
Ad

Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts.pdf

  • 1. V Tổng quan về cấu trúc dữ liệu và giải thuật Cấu trúc dữ liệu là gì? Giải thuật là gì? Cài đặt môi trường Giải thuật tiệm cận Giải thuật tham lam Giải thuật chia để trị Giải thuật qui hoạch động Cấu trúc dữ liệu mảng Cấu trúc dữ liệu Linked List Cấu trúc dữ Doubly Linked List Cấu trúc dữ Circular Linked List Cấu trúc dữ liệu ngăn xếp - Stack Cấu trúc dữ hàng dợi - Queue Cấu Trúc Dữ Liệu & Giải Thuật Giải Thuật Cấu Trúc Dữ Liệu Mảng Danh sách liên kết - Linked list Ngăn Xếp & Hàng Đợi Một Số Giải Thuật Tìm Kiếm  Cấu trúc dữ liệu mảng Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List)  Cấu trúc dữ liệu danh sách liên kết (Linked List) Nội dung chính Danh sách liên kết (Linked List) là gì? Biểu diễn danh sách liên kết (Linked List) Các loại Danh sách liên kết (Linked List) Các hoạt động cơ bản trên Danh sách liên kết Hoạt động chèn trong Danh sách liên kết Hoạt động xóa trong Danh sách liên kết Hoạt động đảo ngược Danh sách liên kết Danh sách liên kết (Linked List) là gì? Một danh sách liên kết (Linked List) là một dãy các cấu trúc dữ liệu bao gồm một nhóm các nút (node) được kết nối với nhau thông qua các liên kết (link) tạo thành một chuỗi. Mỗi nút gồm dữ liệu ở nút đó và tham chiếu đến nút kế tiếp trong chuỗi. Danh sách liên kết là cấu trúc dữ liệu được sử dụng phổ biến thứ hai sau mảng. Dưới đây là các khái niệm cơ bản liên quan tới Danh sách liên kết: Link (liên kết): mỗi link của một Danh sách liên kết có thể lưu giữ một dữ liệu được gọi là một phần tử. Next: Mỗi liên kết của một Danh sách liên kết chứa một link tới next link được gọi là Next. First: một Danh sách liên kết bao gồm các link kết nối tới first link được gọi là First. Recent Updates Xuất dữ liệu ra màn hình console trong Java Cài đặt môi trường Java Java Swing - Bài tập quản lý sinh viên trong java LinkedList trong java ArrayList trong java Bài tập java có lời giải Xác thực dữ liệu (Data Validation) trong Excel Sắp xếp dữ liệu trong Excel Lọc dữ liệu (Data Filter) trong Excel Header và Footer trong Excel Màu văn bản và màu nền (background) trong Excel Căn chỉnh văn bản trong Excel Sắp Tết 2026 Rồi! - Còn bao nhiêu ngày nữa là đến tết 2026? VietTuts on facebook Home Java Servlet JSP Struts2 Hibernate Spring MyBatis Java WS C C++ C# Python PHP Excel VBA Web SQL Misc Học Lập Trình Online Học Lập Trình Online … … 5.672 người theo dõi 5.672 người theo dõi Theo dõi Trang Chia sẻ 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 1/7 Tìm kiếm tuyến tính - Linear Search Tìm kiếm nhị phân - Binary Search Tìm kiếm nội suy - Interpolation Search Cấu trúc dữ liệu Hash Table Giải thuật sắp xếp Sắp xếp nổi bọt - Bubble Sort Sắp xếp chèn - Insertion Sort Sắp xếp chọn - Selection Sort Sắp xếp trộn - Merge Sort Sắp xếp nhanh - Quick Sort Giải thuật Shell Sort Giải thuật quay lui - Back Tracking Cấu trúc dữ liệu đồ thị Tìm kiếm theo chiều sâu - Depth First Search Tìm kiếm theo chiều sâu - Breadth First Search Một Số Giải Thuật Sắp Xếp Cấu Trúc Dữ Liệu Đồ Thị (Graph) Biểu diễn danh sách liên kết (Linked List) Danh sách liên kết có thể được biểu diễn như là một chuỗi các nút (node). Mỗi nút sẽ trỏ tới nút kế tiếp. Dưới đây là một số điểm cần nhớ về Danh sách liên kết: Danh sách liên kết chứa một phần tử link thì được gọi là First. Mỗi link mang một trường dữ liệu và một trường link được gọi là Next. Mỗi link được liên kết với link kế tiếp bởi sử dụng link kế tiếp của nó. Link cuối cùng mang một link là null để đánh dấu điểm cuối của danh sách. Các loại Danh sách liên kết (Linked List) Dưới đây là các loại Danh sách liên kết (Linked List) đa dạng: Danh sách liên kết đơn (Simple Linked List): chỉ duyệt các phần tử theo chiều về trước. Danh sách liên kết đôi (Doubly Linked List): các phần tử có thể được duyệt theo chiều về trước hoặc về sau. Danh sách liên kết vòng (Circular Linked List): phần tử cuối cùng chứa link của phần tử đầu tiên như là next và phần tử đầu tiên có link tới phần tử cuối cùng như là prev. Các hoạt động cơ bản trên Danh sách liên kết Dưới đây là một số hoạt động cơ bản có thể được thực hiện bởi một danh sách liên kết: Hoạt động chèn: thêm một phần tử vào đầu danh sách liên kết. Hoạt động xóa (phần tử đầu): xóa một phần tử tại đầu danh sách liên kết. Hiển thị: hiển thị toàn bộ danh sách. Hoạt động tìm kiếm: tìm kiếm phần tử bởi sử dụng khóa (key) đã cung cấp. 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 2/7 Hoạt động xóa (bởi sử dụng khóa): xóa một phần tử bởi sử dụng khóa (key) đã cung cấp. Hoạt động chèn trong Danh sách liên kết Việc thêm một nút mới vào trong danh sách liên kết không chỉ là một hoạt động thêm đơn giản như trong các cấu trúc dữ liệu khác (bởi vì chúng ta có dữ liệu và có link). Chúng ta sẽ tìm hiểu thông qua sơ đồ dưới đây. Đầu tiên, tạo một nút bởi sử dụng cùng cấu trúc và tìm vị trí để chèn nút này. Giả sử chúng ta cần chèn một nút B vào giữa nút A (nút trái) và C (nút phải). Do đó: B.next trỏ tới C. Output: NewNode.next −> RightNode; Hình minh họa như sau: Bây giờ, next của nút bên trái sẽ trở tới nút mới. Output: LeftNode.next −> NewNode; 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 3/7 Quá trình trên sẽ đặt nút mới vào giữa hai nút. Khi đó danh sách mới sẽ trông như sau: Các bước tương tự sẽ được thực hiện nếu chèn nút vào đầu danh sách liên kết. Trong khi đặt một nút vào vị trí cuối của danh sách, thìnút thứ hai tính từ nút cuối cùng của danh sách sẽ trỏ tới nút mới và nút mới sẽ trỏ tới NULL. Hoạt động xóa trong Danh sách liên kết Hoạt động xóa trong Danh sách liên kết cũng phức tạp hơn trong cấu trúc dữ liệu khác. Đầu tiên chúng ta cần định vị nút cần xóa bởi sử dụng các giải thuật tìm kiếm. Bây giờ, nút bên trái (prev) của nút cần xóa nên trỏ tới nút kế tiếp (next) của nút cần xóa. Output: LeftNode.next −> TargetNode.next; 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 4/7
  • 2. Quá trình này sẽ xóa link trỏ tới nút cần xóa. Bây giờ chúng ta sẽ xóa những gì mà nút cần xóa đang trỏ tới. Output: TargetNode.next −> NULL; Nếu bạn cần sử dụng nút đã bị xóa này thì bạn có thể giữ chúng trong bộ nhớ, nếu không bạn có thể xóa hoàn toàn hẳn nó khỏi bộ nhớ. Hoạt động đảo ngược Danh sách liên kết Với hoạt động này, bạn cần phải cẩn thận. Chúng ta cần làm cho nút đầu (head) trỏ tới nút cuối cùng và đảo ngược toàn bộ danh sách liên kết. Đầu tiên, chúng ta duyệt tới phần cuối của danh sách. Nút này sẽ trỏ tới NULL. Bây giờ điều cần làm là làm cho nút cuối này trỏ tới nút phía trước của nó. 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 5/7  Cấu trúc dữ liệu mảng Cấu trúc dữ liệu danh sách liên kết đôi (Doubly Linked List)  Chúng ta phải đảm bảo rằng nút cuối cùng này sẽ không bị thất lạc, do đó chúng ta sẽ sử dụng một số nút tạm (temp node – giống như các biến tạm trung gian để lưu giữ giá trị). Tiếp theo, chúng ta sẽ làm cho từng nút bên trái sẽ trỏ tới nút trái của chúng. Sau đó, nút đầu tiên sau nút head sẽ trỏ tới NULL. Chúng ta sẽ làm cho nút head trỏ tới nút đầu tiên mới bởi sử dụng các nút tạm. Bây giờ danh sách liên kết đã bị đảo ngược. Danh Sách Bài Học Bài Tập Có Lời Giải Câu Hỏi Phỏng Vấn 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 6/7 Học Java | Hibernate | Spring Học Excel | Excel VBA Học Servlet | JSP | Struts2 Học C | C++ | C# Học Python Học SQL Bài tập Java Bài tập C Bài tập C++ Bài tập C# Bài tập Python Ví dụ Excel VBA 201 câu hỏi phỏng vấn java 25 câu hỏi phỏng vấn servlet 75 câu hỏi phỏng vấn jsp 52 câu hỏi phỏng vấn Hibernate 70 câu hỏi phỏng vấn Spring 57 câu hỏi phỏng vấn SQL Copyright © 2016 VietTuts.Vn all rights reserved. | Liên hệ | Chính sách - riêng tư | sitemap.html | sitemap_index.xml 18:16 23/6/25 Cấu trúc dữ liệu danh sách liên kết (Linked List) - VietTuts https://viettuts.vn/cau-truc-du-lieu-va-giai-thuat/cau-truc-du-lieu-linked-list 7/7