14/08/2018, 12:30

Cấu trúc dữ liệu và giải thuật Danh sách liên kết đôi

Danh sách liên kết đôi (Doubly Linked List) là gì ? Danh sách liên kết đôi (Doubly Linked List) là một biến thể của Danh sách liên kết (Linked List), trong đó hoạt động duyệt qua các nút có thể được thực hiện theo hai chiều: về trước và về sau một cách dễ dàng khi so sánh với Danh sách liên ...

Danh sách liên kết đôi (Doubly Linked List) là gì ?

Danh sách liên kết đôi (Doubly Linked List) là một biến thể của Danh sách liên kết (Linked List), trong đó hoạt động duyệt qua các nút có thể được thực hiện theo hai chiều: về trước và về sau một cách dễ dàng khi so sánh với Danh sách liên kết đơn. Dưới đây là một số khái niệm quan trọng cần ghi nhớ về Danh sách liên kết đôi.

Biểu diễn Danh sách liên kết đôi

Danh sách liên kết đôi (Doubly Linked List)

Như hình minh họa trên, bạn cần ghi nhớ:

Các hoạt động cơ bản trên Danh sách liên kết đôi

Hoạt động chèn trong Danh sách liên kết đôi

Phần dưới đây là giải thuật minh họa cho hoạt động chèn tại vị trí đầu của một Danh sách liên kết đôi.

//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()) {
      //Biến nó thành last link
      last = link;
   }else {
      //Cập nhật prev link đầu tiên
      head->prev = link;
   }

   //Trỏ nó tới first link cũ
   link->next = head;
	
   //Trỏ first tới first link mới
   head = link;
}

Để tìm hiểu chi tiết code minh họa của danh sách liên kết đôi trong ngôn ngữ C, mời bạn click chuột vào chương: Chương trình danh sách liên kết đôi trong C.

Hoạt động xóa trong Danh sách liên kết đôi

Phần dưới đây là giải thuật minh họa cho hoạt động xóa phần tử tại vị trí đầu của một Danh sách liên kết đôi.

//xóa phần tử đầu tiên
struct node* deleteFirst() {

   //Lưu tham chiếu tới first link
   struct node *tempLink = head;
	
   //Nếu chỉ có link
   if(head->next == NULL) {
      last = NULL;
   }else {
      head->next->prev = NULL;
   }
	
   head = head->next;
	
   //Trả về link đã bị xóa
   return tempLink;
}

Để tìm hiểu chi tiết code minh họa của danh sách liên kết đôi trong ngôn ngữ C, mời bạn click chuột vào chương: Chương trình danh sách liên kết đôi trong C.

Hoạt động chèn tại vị trí cuối trong Danh sách liên kết đôi

Phần dưới đây là giải thuật minh họa cho hoạt động chèn tại vị trí cuối của một Danh sách liên kết đôi.

//Chèn link vào vị trí cuối cùng
void insertLast(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()) {
      //biến nó thành last link
      last = link;
   }else {
      //làm cho link trở thành last link mới
      last->next = link;     
      //Đánh dấu last node là prev của new link
      link->prev = last;
   }

   //Trỏ last tới new last node
   last = link;
}

Để tìm hiểu chi tiết code minh họa của danh sách liên kết đôi trong ngôn ngữ C, mời bạn click chuột vào chương: Chương trình danh sách liên kết đôi trong C.

Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.

Bài học Cấu trúc dữ liệu và giải thuật phổ biến tại code24h.com:

0