Danh sách liên kết vòng (Circular Linked List) là một biến thể của Danh sách liên kết (Linked List), trong đó phần tử đầu tiên trỏ tới phần tử cuối cùng và phần tử cuối cùng trỏ tới phần tử đầu tiên.
Cả hai loại Danh sách liên kết đơn (Singly Linked List) và Danh sách liên kết đôi (Doubly Linked List) đều có thể được tạo thành dạng Danh sách liên kết vòng. Phần dưới chúng ta sẽ tìm hiểu từng cách tạo một.
Trong Danh sách liên kết đơn, điểm trỏ tới kế tiếp của nút cuối sẽ trỏ tới nút đầu tiên, thay vì sẽ trỏ tới NULL.
Trong Danh sách liên kết đôi, điểm trỏ tới kế tiếp của nút cuối trỏ tới nút đầu tiên và điểm trỏ tới phía trước của nút trước sẽ trỏ tới nút cuối cùng. Quá trình này sẽ tạo thành vòng ở cả hai hướng.
Nhìn vào hai hình minh họa trên, bạn cần ghi nhớ:
Dưới đây là một số hoạt động cơ bản được hỗ trợ bởi Danh sách liên kết vòng:
Dưới đây là giải thuật minh họa hoạt động chèn trong Danh sách liên kết vòng dựa trên Danh sách liên kết đơn.
//Chèn link tại vị trí đầu tiên
void insertFirst(int key, int data) {
//tạo một link
struct node *link = (struct node*) malloc(sizeof(struct node));
link->key = key;
link->data= data;
if (isEmpty()) {
head = link;
head->next = head;
}else {
//trỏ nó tới first node cũ
link->next = head;
//trỏ first tới first node mới
head = link;
}
}
Dưới đây là giải thuật minh họa hoạt động xóa trong Danh sách liên kết vòng dựa trên Danh sách liên kết đơn.
//Xóa phần tử đầu tiên
struct node * deleteFirst() {
//Lưu tham chiếu tới first link
struct node *tempLink = head;
if(head->next == head){
head = NULL;
return tempLink;
}
//Đánh dấu next tới first link là first
head = head->next;
//trả về link đã bị xóa
return tempLink;
}
Dưới đây là giải thuật minh họa hoạt động hiển thị toàn bộ Danh sách liên kết vòng.
//Hiển thị danh sách liên kết vòng
void printList() {
struct node *ptr = head;
printf("\n[ ");
//Bắt đầu từ vị trí đầu tiên
if(head != NULL) {
while(ptr->next != ptr) {
printf("(%d,%d) ",ptr->key,ptr->data);
ptr = ptr->next;
}
}
printf(" ]");
}
Unpublished comment
Viết câu trả lời