Cấu trúc động và ứng dụng

25 480 0
Cấu trúc động và ứng dụng

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

Cấu trúc đống có rất nhiều ứng vào các giải thuật nhưgiả thuật sắp xếp đống, vào hàng đợi ưu tiên.

Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Mục Lục Phần 1:MỞ ĐẦU 3 I.Lí do chọn đề tài .3 Phần 2:Nội Dung .3 Chương 1 : Cơ sở lý thuyết về cây nhị phân .3 I. Định nghĩa các ví dụ 3 1. Định nghĩa 3 2.Ví dụ .4 II. Cây nhị phân .4 1. Định nghĩa các tính chất .4 2. Biểu diễn cây nhị phân .5 Chương 2. Cấu trúc đống 7 I. Định nghĩa .7 1.Định nghĩa .7 2. Heap có các tính chất sau : .7 3. Ví dụ : .8 4) Thuật giải .8 II. Các phép toán của Heap 9 1. Thêm một phần tử vào Heap .9 2. Xoá một phần tử nhỏ nhất khỏi Heap. 10 Chương 3: Các ứng dụng của Đống .11 I. Ứng dụng của Heap trong giải thuật Heap_sort .11 1.Giải thuật .11 II.Ứng dụng đống tổ chức hàng đợi có ưu tiên .16 1.Ứng dụng của đống trong giải thuật Hufman .16 2.Ứng dụng của đống trong giải thuật xây dựng cây bao trùm nhỏ nhất của đồ thị liên thông : .19 1 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Chương 4: Mô phỏng cài đặt cấu trúc đốngứng dụng 21 I.Mô phỏng thuật toán 21 1.Khái niệm chung về mô phỏng thuật toán 21 2.Mục đích của mô phỏng thuật toán 22 3.Cấu trúc tổng quan của mô phỏng thuật toán: .22 4. Quy trình thiết kế nhiệm vụ của mô phỏng thuật toán 22 2 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Phần 1:MỞ ĐẦU I. Lí do chọn đề tài. Hiện nay, công nghệ thông tin với tốc độ phát triển rất nhanh. Các nhà khoa học khẳng định rằng chưa có một ngành khoa học - công nghệ nào lại có nhiều ứng dụng như công nghệ thông tin. Việc ứng dụng công nghệ thông tin vào trong giáo dục đã trở thành mối ưu tiên hàng đầu của nhiều quốc gia trong đó có Việt Nam. Trong quá trình học các giải thuật nói chung môn cấu trúc dữ liệu nói riêng, chúng ta rút ra một nhận định chung là: nhiều giải thuật phức tạp trừu tượng, khó hiểu, khó hình dung vấn đề. Do đó chúng ta luôn mong muốn trong quá trình học giải thuật nên có những mô phỏng trực quan để chúng ta có thể tiếp thu giải thuật một cách dễ dàng hơn. Tuy nhiên, việc học tốt giải thuật có rất nhiều thận lợi dó là giúp cho quá trình tư duy giải thật tốt hơn, phát hiện vấn đề nhanh hơn, đặc biệt giúp cho việc học các môn học khác có tính logic cao được thuận lợi hơn. Nhưng để học tốt giải thuật thì không dễ dàng với nhiều người. Vậy để giúp người học tiếp thu một cách dễ dàng các giải thuật thì phải xây dựng các phần mền mô phỏng thuật toán. Cấu trúc đống có rất nhiều ứng vào các giải thuật nhưgiả thuật sắp xếp đống, vào hàng đợi ưu tiên. Nghiên cứu cấu trúc đống để hiểu thêm về nó phục vụ trong việc giải quyết các bài toán Phần 2:Nội Dung Chương 1 : Cơ sở lý thuyết về cây nhị phân. I. Định nghĩa các ví dụ 1. Định nghĩa. Cây là một cấu trúc phi tuyến tính. Một cây (tree) là một tập hữu hạn các nút trong đó có một nút đặc biệt gọi là nút gốc (root), giữa các nút có một mối quan hệ phân cấp gọi là quan hệ “cha - con”. Có thể định nghĩa cây một cách đệ quy như sau: 1. Một nút là một cây. Nút đó cũng là gốc của cây ấy. 3 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng 2. Nếu T 1 , T 2 , ., T n là các cây, với n 1 , n 2 , . n k lần lượt là các gốc, n là một nút n có quan hệ cha - con với n 1 , n 2 , . n k thì lúc đó một cây mới T sẽ được tạo lập, với n là gốc của nó. n được gọi là cha của n 1 , n 2 , . n k ; ngược lại n 1 , n 2 , . n k được gọi là con của n. Các cây T 1 , T 2 , ., T n được gọi là các cây con (substrees) của n. Ta quy ước : Một cây không có nút nào được gọi là cây rỗng (null tree). Có nhiều đối tượng có cấu trúc cây. 2.Ví dụ . a) Mục lục của một cuốn sách, hoặc một chương trong sách, có cấu trúc cây. b) Biểu thhức số học x + y * (z – t) + u/v, ta có thể biểu diến dưới dạng cây như hình 1. Hình 1 II. Cây nhị phân. 1. Định nghĩa các tính chất. Cây nhị phân là một dạng quan trọng của cấu trúc cây. Cây nhị phân có các đặc điểm là: Mọi nút trên cây chỉ có tối đa là 2 con. Đối với cây con của một nút người ta cũng phân biệt cây con trái (left subtree) cây con phải (right subtree). Như vậy cây nhị phân là cây có thứ tự. Ví dụ : Cây ở hình 1 là cây nhị phân với toán tử ứng với gốc, toán hạng 1 ứng với cây con trái, toán hạng 2 ứng với cây con phải. Các cây nhị phân sau đây là khác nhau, nhưng nếu coi là cây không có thứ tự thì chúng chỉ là 1. 4 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng 2. Biểu diễn cây nhị phân a) Lưu trữ kế tiếp Nếu có một cây nhị phân đầy đủ, ta có thể dễ dàng đánh số cho các nút trên cây đó theo thứ tự lần lượt từ mức 1 trở lên, hết mức này đến mức khác từ trái sang phải đối với các nút ở mỗi mức. Ví dụ : Với hình cây f) có thể đánh số như sau : Hình 2 Ta thấy ngay một quy luật đệ quy trái như sau : Con của các nút thứ i là các nút thứ 2i 2i + 1 hoặc Cha của nút thứ j là j/2 Nếu như vậy thì ta có thể lưu trữ cây nhị phân đầy đủ bằng một vectơ V, theo nguyên tắc: nút thứ i của cây được lưu trữ ở V[i]. Đó chính là cách lưu trữ kế tiếp đối với cây nhị phân. Với cách lưu trữ này nếu biết được địa chỉ nút cha sẽ tính được địa chỉ nút con ngược lại. Như vậy với cây đầy đủ nêu trên thì hình ảnh lưu trữ sẽ như sau : Tất nhiên với cây nhị phân hoàn chỉnh, mà các nút ở mức cuối đều đạt về phía trái (để việc đánh số các nút này được liên tục ) thì cách lưu trữ này vẫn thích hợp. Còn với cây nhị phân dạng khác thì cách lưu trữ này có thể gây lãng phí do có nhiều phần tử nhớ bị bỏ trống(ứng với cây con rỗng). Chẳng hạn đối với cây lệch trái thì phải lưu trữ bằng một véc tơ . 5 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Ngoài ra nếu cây luôn biến động nghĩa là có phép bổ sung, loại bỏ các nút thường xuyên tác động, thì cách lưu trữ này tất không tránh được các nhược điểm như đã nêu trên. Cách lưu trữ móc nối sau đây vừa khắc phục được nhược điểm này, vừa phản ánh được dạng tự nhiên của cây. b) Lưu trữ móc nối Trong cách lưu trữ này, mỗi nút ứng với một phần tử nhớ có quy cách như sau : LPTR INFO RPTR Trong đó : - Trường INFO ứng với thông tin (dữ liệu) của nút. - Trường LPTR ứng với con trỏ, trỏ tới cây con trái của nút đó. - Trường RPTR ứng với con trỏ, trỏ tới cây con phải của nút đó. Ví dụ : Cây nhị phân Hình 3 Cây nhị phân trong hình 3 có dạng lưu trữ móc nối như hình sau : 6 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Hình 4 Để có thể truy nhập vào các nút trên cây cần có một con trỏ T, trỏ tới nút gốc của cây đó. Người ta quy ước : Nếu cây nhị phân rỗng thì T = Null. Với cách biểu diễn này từ nút cha có thể truy nhập trực tiếp vào nút con, nhưng ngược lại thì không làm được. Chương 2. Cấu trúc đống. I. Định nghĩa . 1.Định nghĩa. Đống (Heap) là một cây nhị phân gắn nhãn với các nhãn là các giá trị thuộc tập hợp được sắp thứ tự tuyến tính, sao cho những điều kiện sau đây được thực hiện: 1.Tất cả các mức của cây đều đầy, trừ mức thấp nhất có thể thiếu một số đỉnh. 2.Ở mức thấp nhất, tất cả các lá đều xuất hiện liên tiếp từ bên trái. 3. Giá trị ở mỗi đỉnh không lớn hơn giá trị của các đỉnh con của nó Với điều kiện này thì không đảm bảo Heap là một cây nhị phân tìm kiếm. 2. Heap có các tính chất sau : Tính chất 1 : Nếu ap , a2 , . , aq là một Heap thì khi cắt bỏ một số phần tử ở hai đầu của Heap, dãy con còn lại vẫn là một Heap. Tính chất 2 : Mọi dãy ap , a2 , . , aq, dãy con aj, aj+1,…, ar tạo thành một Heap với j=(q div 2 +1). 7 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng 3. Ví dụ : Đống được lưu trong máy bởi một mảng a[1 n], với gốc ở phần tử thứ nhất, con bên trái của đỉnh a[i] là a[2*i] con bên phải là a[2*i+1] (với 2*i<=n 2*i+1<=n). Khi đó nếu như a[i] <= a[2*i] a[2*i+1] với mọi i = 1 int(n/2). thì trong đống a[1] (tương ứng là gốc của cây) là phần tử nhỏ nhất. Đây là Heap (Hình 5) 4) Thuật giải. 1.Xem mảng ban đầu là một cây nhị phân. Mỗi nút trên cây lưu trữ một phần tử mảng, trong đó a[1] là nút gốc mỗi nút không là nút lá a[i] có con trái là a[2*i] con phải là a[2*i+1]. Với cách tổ chức này thì cây nhị phân thu được sẽ có các nút trong là các nút a[1]…, a[n DIV 2]. Tất cả các nút trong đều có hai con, ngoại trừ nút a[n DIV 2] có thể chỉ có một con trái (trong trường hợp n là một số chẵn). 2.Sắp xếp dãy ban đầu thành Heap căn cứ vào giá trị khoá của các nút. 3.Hoán đổi a[1] cho phần tử cuối cùng. 4.Sắp lại cây sau khi đã bỏ đi phần tử cuối cùng để nó trở thành một heap mới. Lặp lại quá trình (3) (4) cho tới khi cây chỉ còn một nút ta sẽ được mảng sắp theo thứ tự giảm 8 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng II. Các phép toán của Heap. 1. Thêm một phần tử vào Heap. Để xen một phần tử mới vào Heap, đầu tiên ta thêm một lá mới liền kề với các lá ở mức thấp nhất, nếu mức thấp nhất chưa đầy; còn nếu mức thấp nhất đầy, thì ta thêm vào một lá ở mức mới sao cho các điều kiện 1 2 của Heap được bảo tồn.Trong hình 6a dưới sau khi thêm nút lá có giá trị 3 vào mức cuối cùng thì cây không còn là Heap. Nếu sau khi thêm vào lá mới cây không còn là heap, thì ta theo đường từ lá mới tới gốc cây. Nếu một đỉnh có giá trị nhỏ hơn đỉnh cha của nó, thì ta trao đổi đỉnh đó với cha của nó. Sau quá trình biến đổi đó thì ta có một Heap hình 6c. Hình 6a Hình 6b 9 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Hình 6c 2. Xoá một phần tử nhỏ nhất khỏi Heap. Sét một Min Heap thì hiển nhiên gốc của cây sẽ có giá trị nhỏ nhất. Tuy nhiên nếu loại bỏ gốc thì cây không còn là cây nữa. Do đó ta tiến hành như sau: đặt vào gốc phần tử của hàng ưu tiên chứa trong lá ngoài cùng bên phải ở mức thấp nhất, sau đó loại bỏ lá này ra khỏi cây. Hình 6a minh hoạ cây nhận được từ cây trong hình 6 sau phép biến đổi.Tới đây cây không còn là heap vì điều kiện 3 của định nghĩa Heap bị vi phạm ở gốc cây. Bây giờ ta đi từ gốc xuống. Giả sử tại một bước nào đó ta đang ở đỉnh a hai đỉnh con của nó tại b c. Để xác định, ta giả sử rằng giá trị ưu tiên của ít nhất hơn giá trị ưu tiên của đỉnh c pri(b) <= pri(c). Khi đó ta sẽ trao đổi đỉnh a với đỉnh b đi xuống đỉnh b. Quá trình đi sẽ dừng lại cùng lắm là khi ta đạt tới một lá của cây. Có thê thấy quá trình diễn ra ở hình 7b 7c (a) 10 [...]... tách dữ liệu, thao tác tạo giao diện đồ hoạ mô phỏng cho quá trình đó 21 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng 2.Mục đích của mô phỏng thuật toán Mô phỏng thuật toán sử dụng đồ hoạ để mô tả các cấu trúc dữ liệu bên trong của thuật toán được thực hiện trong chương trình biểu diễn sự thay đổi của các cấu trúc dữ liệu trong mỗi trạng thái thực thi các hoạt động của chương trình...Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng (b) (c) Hình 7 Chương 3: Các ứng dụng của Đống I Ứng dụng của Heap trong giải thuật Heap_sort 1.Giải thuật HeapSort là một giải thuật dựa vào cấu trúc đống để sắp xếp theo thứ tự giảm dần của các giá trị khoá là số Giải thuật Heapsort trải qua 2 giai đoạn : Giai... n] có tần suất tương ứng là W[1 n] + Tạo hàng đợi bằng đống: 18 Báo cáo nghiên cứu khoa học Cấu trúc đốngứng dụng Ta tạo một đống trên cơ sở sắp xếp lại các chỉ số của A W Ta lưu trữ đống dưới dạng mảng, kí hiệu nó là Heap[1 n] Trước hết đưa chỉ số của các chữ cái theo thứ tự ban đầu vào mảng Heap[1 n] với Heap[i]=i với mọi i=1 n Ta sẽ lưu trữ cấu trúc của cây mã Huffman vào một mảng Cây Huffman... con trái giá trị khoá tương ứng của nó lớn hơn con trái của nó nên ta đổi chỗ hai nút này cho nhau do con trái của a[5] là a[10] là một nút lá nên việc đẩy xuống của a[5] là kết thúc Hình 9 12 Báo cáo nghiên cứu khoa học Cấu trúc đốngứng dụng Tiếp theo xét nút a[4] a[3] đã đúng vị trí nên không phải thực hiện sự hoán đổi nữa Xét nút a[2], so sánh thấy giá trị a[2] = 6 > a[4] = 2 a[4]... điều khác biệt là ta sẽ sử dụng một hàng đợi có ưu tiên, tiêu chuẩn ưu tiên ở đây là cạnh nối đỉnh sẽ được bổ sung vào T là nhỏ nhất Một cấu trúc thuận lợi 20 Báo cáo nghiên cứu khoa học Cấu trúc đốngứng dụng cho hàng đợi có ưu tiên là cấu trúc đống (heap) như đã sử dụng trong giải thuật sắp xếp vun đống hoặc giải thuật xây dựng mã Huffman Giả sử G=(X,E) là đồ thị liên thông, Ajd(u), là danh sách đỉnh... Tiếp tục thực hiện quá trình trên ta được một mảng sắp theo thứ tự giảm là Hình 16 15 Báo cáo nghiên cứu khoa học Cấu trúc đốngứng dụng II .Ứng dụng đống tổ chức hàng đợi có ưu tiên 1 .Ứng dụng của đống trong giải thuật Hufman a) Giới thiệu về thuật toán Huffman: -Trong khoa học máy tính lý thuyết thông tin, mã Hufffman là một thuật toán mã hoá dùng để nén dữ liệu Nó dựa trên bảng tần suất xuất... trước, khi muốn sử dụng chỉ việc lấy ra Có tác dụng là cho người sử dụng đỡ mất công nhập lại dữ liệu (trong trường hợp dữ liệu quá lớn thì mất thời gian), hoặc để kiểm định thuật toán trong các trường hợp xấu, trung bình hoặc tốt 23 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Dữ liệu nhập là dữ liệu do người dùng nhập vào từ bàn phím, đa số thì dạng dữ liệu này thường được sử dụng vì người dùng... nhắc đến là thuật toán Prim thuật toán Krusskal 19 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng a)Bài toán Cho G=(X,E) là một đồ thị liên thông Ngoài ra, một hàm trọng số W(e) nhận các giá trị thực, xác định trên tập các cạnh E của G Cả hai thuật toán Prim Kruskal đều dựa trên tư tưởng của các giải thuật tham lam: Ở mỗi bước của thuật toán ta chọn bổ sung vào cây cạnh có trọng số nhỏ... bộ mã của H, O, N, G, A, I trong ví - dụ trên Hình 17 c) Giải thuật Huffman - Một ứng dụng nữa của Heap là vào giải thuật Huffman Thành lập cây nhị phân từ tập hợp các ký hiệu trong thông báo, mỗi ký hiệu là một nút lá cây Cách thành lập cây như sau: *Dữ liệu: + Input: 17 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng Bảng n chữ cái Ch[1 n] Tập các trọng số (tần suất xuất hiện) của n ký tự cho... hợp ngẫu nhiên, trường hợp xấu nhất, trường hợp tốt nhất *Tạo mức độ sử dụng khác nhau cho người học 3 .Cấu trúc tổng quan của mô phỏng thuật toán: 4 Quy trình thiết kế nhiệm vụ của mô phỏng thuật toán Quy trình thiết kế nhiệm vụ mô phỏng thuật toán được tiến hành theo sơ đồ sau: 22 Báo cáo nghiên cứu khoa học Cấu trúc đống ứng dụng a) Nghiên cứu phân tích giải thuật Trong khi giải bài toán chúng ta . thuật nói chung và môn cấu trúc dữ liệu nói riêng, chúng ta rút ra một nhận định chung là: nhiều giải thuật phức tạp trừu tượng, khó hiểu, khó hình dung vấn. tài.......................................................................................................3 Phần 2:Nội Dung. ....................................................................3 Chương

Ngày đăng: 25/04/2013, 09:19

Từ khóa liên quan

Tài liệu cùng người dùng

  • Đang cập nhật ...

Tài liệu liên quan