Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 38 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
38
Dung lượng
613,5 KB
Nội dung
Bài tập chủ đề lớn 1 MỤC LỤC . 1 LỜI MỞ ĐẦU . 2 A.VẤN ĐỀ, MỤC ĐÍCH VÀ PHẠM VI NGHIÊN CỨU CỦA ĐỀ TÀI . 4 B. TÌM HIỂU VỀ BÀI TOÁN SẮPXẾP 5 C. NỘI DUNG CỦA CÁCPHƯƠNGPHÁPSẮPXẾP . 7 I. Phươngpháp chọn trực tiếp (Selection sort): .7 1. Giải thuật: .7 2. Đánh giá giải thuật: 9 3. Lưu đồ thuật toán : .9 II. Phươngpháp chèn trực tiếp (Insert sort): .10 1. Giải thuật: .10 2. Đánh giá giải thuật : .11 3. Lưu đồ thuật toán: 12 Xem như dãy số cần sắpxếp đã được nhập vào sẵn: 12 III. Phươngphápsắpxếp nổi bọt (Bubble sort): .13 1. Giải thuật : 13 Dãy khi sắpxếp xong là : 1 2 4 5 6 8 12 15 .15 2. Đánh giá giải thuật : .15 Nhận xét: .15 IV. Phươngphápsắpxếp vun đống (Heap sort): 17 1. Định nghĩa heap : .17 2. Giải thuật Heapsort: .17 3. Đánh giá giải thuật : .20 V. Phươngphápsắpxếp nhanh (Quick sort): 22 1. Giải thuật : 22 2. Đánh giá giải thuật : .24 3. Lưu đồ thuật toán : .25 Xem như dãy số cần sắpxếp đã được nhập vào sẵn .25 VI. Phươngphápsắpxếp trộn (MergerSort): 26 2. Đánh giá giải thuật: .28 3. Lưu đồ thuật toán: 28 D. KẾT LUẬN .31 32 32 - Sau đó nhấn Enter để vào menu chương trình chính để ta lựa chọn cácphươngphápsắpxếp và để lựa chọn cácphươngphápsắpxếp ta sử dụng 2 phím mũi tên lên hoặc là xuống. Minh họa màn hình giao diện xuất hiện như sau: 32 33 .33 - Tiếp tục nhấn Enter thì màn hình sẽ quay lại màn hình chương trình Demo1 như ban đầu 34 TÀI LIỆU THAM KHẢO 35 PHIẾU NHẬN XÉT CỦA GIÁO VIÊN HƯỚNG DẪN VÀ GIÁO VIÊN CHẤM .35 1 Bài tập chủ đề lớn 1 PHIẾU CHẤM ĐIỂM BÀI TẬP CHỦ ĐỀ LỚN 1 .36 Hiện nay trong hầu hết các hệ lưu trữ, quản lý dữ liệu, thao tác tìm kiếm thường được thực hiện nhiều nhất để khai thác thông tin một cách nhanh chóng(ví dụ như : tra cứu từ điển, tìm sách trong thư viện .) và muốn việc tìm kiếm cách nhanh chóng thì dữ liệu cần phải được sắpxếp sẵn, ngăn nắp theo một trật tự, hệ thống nhất định sẽ cho phép chúng ta tìm kiếm nhanh, việc tìm kiếm, sắpxếp có ý nghĩa rất lớn trong việc quản lí và lưu trữ . Do đó khi xây dựng một hệ quản lý thông tin trên máy tính, bên cạnh các thuật toán tìm kiếm, các thuật toán sắpxếp dữ liệu cũng là một trong những chủ đề được quan tâm hàng đầu. Hiện nay đã có nhiều giải thuật tìm kiếm và sắpxếp được xây dựng, mức độ hiệu quả của từng giải thuật còn phụ thuộc vào tính chất của cấu trúc dữ liệu cụ thể mà nó tác động đến mà ta lựa chọn phươngphápsắpxếp sao cho phù hợp. Trong khoa học máy tính và trong toán học, một thuật toán sắpxếp là một thuật toán sắpxếpcác phần tử của một danh sách (hoặc một mảng theo thứ tự tăng dần hoặc giảm dần). Người ta thường xét trường hợp các phần tử cần sắpxếp là các số. Hầu hết các bài toán đều có nhiều thuật toán khác nhau để giải quyết chúng. Nội dung giới thiệu trình bày dưới đây là những thuật toán sắpxếp thông dụng nhất và đó cũng là nội dung mà nhóm chúng em nghiên cứu trong bài tập chủ đề lớn 1 này là: 1. Phươngpháp chọn trực tiếp (Selection sort); 2 Bài tập chủ đề lớn 1 2. Phươngpháp chèn trực tiếp( Insertion sort); 3. Phươngphápsắpxếp nổi bọt( Bubble sort); 4.Phương phápsắpxếp trộn ( Merge sort); 5.Phương phápsắpxếp nhanh ( Quick sort); 6 Phươngphápsắpxếp kiểu vun đống ( Heap sort); Ngoài ra còn có nhiều thuật toán sắpxếp khác nữa như: Phươngphápsắpxếp cải tiến ( Shellsort) Trong bài tập chủ đề lớn 1 này chúng ta sẽ được lần lượt tìm hiểu khảo sát từng thuật toán trên. Các thuật toán như Selection sort, Insertion sort, Bubble sort là những thuật toán đơn giản dễ cài đặt nhưng chi phí cao. Các thuật toán Merge sort, Quick sort, Heap sort, phức tạp hơn nhưng hiệu suất cao hơn nhóm thuật toán đầu. Các nhóm thuật toán trên đều có một điểm chung là đều được xây dựng dựa trên cơ sở so sánh giá trị của các phần tử trong mảng (hay so sánh các khóa tìm kiếm). Khi xây dựng một thuật toán sắpxếp cần chú ý tìm cách giảm thiểu những phép so sánh và đổi chổ không cần thiết để tăng hiệu quả của thuật toán. Mặt dù nhóm chúng em đã rất cố gắng và nổ lực để làm bài tập chủ đề lớn này do kinh nghiệm còn hạn chế và kiến thức chúng em nắm chưa sâu nên chúng em biết sẽ không tránh khỏi những thiếu sót. Nhóm chúng em rất mong nhận được sự thông cảm và đóng góp của các Thầy, Cô để lần sau làm bài tập chủ đề được tốt hơn. Hoàn thành bài tập chủ đề lớn 1 này là niềm vui của cả nhóm, nhóm chúng em rất là biết ơn Thầy Huỳnh Dương Trung Trực đã hướng dẫn chúng em tận tình trong suốt thời gian chúng em làm bài tập chủ đề. Một lần nữa nhóm chúng em xin gửi lời cám ơn chân thành nhất đến Thầy. Sóc Trăng, Ngày 16 Tháng 05 Năm 2010 3 Bài tập chủ đề lớn 1 A. VẤN ĐỀ, MỤC ĐÍCH VÀ PHẠM VI NGHIÊN CỨU CỦA ĐỀ TÀI I. Nêu vấnđề : Quá trình sắpxếp là quá trình bố trí lại các phần tử của một tập đối tượng điển hình như là một dãy số nào đó, một dãy chữ theo thứ tự của từ điển.v.v., nhằm sắpxếp theo một thứ tự nhất định theo thứ tự tăng dần (hoặc giảm dần) đối với một dãy số, thứ tự từ điển đối với một dãy chữ.v.v…. Bài toán sắpxếp thường được xuất hiện thường xuyên nhất trong các ứng dụng tin học như trong ngôn ngữ lập trình Pascal .,với những yêu cầu, mục đích khác nhau thì sắpxếp dữ liệu lưu trữ trong máy tính theo cách và các bước khác nhau….Nói chung, dữ liệu có thể xuất hiện dưới nhiều dạng khác nhau và thường phải lưu trữ một khối lượng dữ liệu đáng kể, nên việc xây dựng các giải thuật sắpxếp sẽ cho phép tìm kiếm nhanh sẽ có ý nghĩa rất lớn. Từ cácvấnđề nêu trên giúp cho chúng em hiểu rỏ mục đích đề tài là: Đểsắpxếpcác dãy số theo một trật tự, thứ tự tăng dần (hoặc là giảm dần) tùy theo vào yêu cầu của người muốn sắp xếp, sắpxếp theo thự tự để giúp cho việc tìm kiếm được dễ dàng hơn, qua đó có thể giúp chúng em hiểu rỏ các ưu khuyết điểm của cácphươngphápsắpxếpđể so sánh tốc độ sắp xếp, từ đó đểvận dụng cácphươngpháp đó trong việc sắpxếp theo yêu cầu cùa bài toán đặt ra một cách có hiệu quả và đó cũng là mục đích mà nhóm chúng em chọn đề tài về cácsắpxếpđể nghiên cứu. II. Phạm vi nghiên cứu của đề tài : Tìm hiểu và vận dụng các lý thuyết cơ bản về một số phươngphápsắpxếp như phươngpháp chọn trực tiếp (Selectsort), chèn trực tiếp (Insertsort), sắpxếp nổi bọt (Bubblesort), sắpxếp kiểu vun đống (Heapsort), sắpxếp nhanh (Quicksort), sắpxếp trộn (Mergesort), để cài đặt chương trình Demo, cho phép sắpxếp một dãy số đã cho tuỳ ý thành một dãy số có thứ tự theo các thuật toán sắpxếp vừa nêu trên. III. Mục tiêu của đề tài cần đạt được: 1. Đối với báo cáo : - Mô tả quá trình thực hiện của tất cả cácphươngphápsắp xếp. 4 Bài tập chủ đề lớn 1 - Tính được độ phức tạp của từng phương pháp. - Thể hiện được tất cả các giao diện trong Demo. - Mô tả các chức năng trong Demo. 2. Đối với Demo : - Thiết kế giao diện hài hoà rõ ràng. Có sử dụng đồ hoạ. - Demo phải có dữ liệu mẫu để test và có chức năng nhập dữ liệu để kiểm tra thủ công. B. TÌM HIỂU VỀ BÀI TOÁN SẮPXẾP I. Định nghĩa về bài toán sắp xếp: 1. Khái niệm về sắp xếp: Sắpxếp là quá trình xử lý một danh sách các phần tử (hoặc các mẫu tin) để đặt chúng theo các thứ tự thỏa mãn một tiêu chuẩn nào đó dựa trên nội dung thông tin lưu giữ tại mọi phần tử. Tại sao cần phải sắpxếpcác phần tử thay vì để nó ở dạng tự nhiên (chưa có thứ tự vốn có? Ví dụ của bài toán tìm kiếm với phươngpháp tìm kiếm nhị phân và tuần tự để trả lời câu hỏi này. Khi khảo sát bài toán sắp xếp, ta sẽ phải làm việc nhiều với một khái niệm gọi là nghịch thế. 2:Khái niệm nghịch thế : Xét một mảng các số a 0 ,a 1 , …, a n . Nếu có i < j và a i > a j , thì ta gọi đó là một nghịch thế. Ví dụ : Mảng chưa sắpxếp sẽ có nghịch thế. Mảng đã có thứ tự sẽ không chứa nghịch thế. Khi đó a 0 sẽ là phấn tử nhỏ nhất rối đến a 1 , a 2 . Như vậy, đểsắpxếp một mảng, ta có thể tìm cách giảm số các nghịch thế trong mảng này bằng cách hoán vị các cặp phần tử a i , a j nếu có i < j và a i > a j theo một quy luật nào đó. Cho trước một dãy số a 1 ,a 2 , …, a n được lưu trữ trong cấu trúc dữ liệu mảng. A : array [1 100] of integer; Sắpxếp dãy số a 1 ,a 2 , …, a n là thực hiện việc bố trí lại các phần tử sao cho hình thành được dãy mới a k1 , a k2 , …, a kn có thứ tự (giả sử xét thứ tự tăng) nghĩa là a ki > a ki-1 . Mà 5 Bài tập chủ đề lớn 1 để quyết định được những tình huống cần thay đổi vị trí các phần tử trong dãy, cần dựa vào kết quả của một loạt phép so sánh. Chính vì vậy, hai thao tác so sánh và gán là các thao tác cơ bản của hầu hết các thuật toán sắp xếp. Khi xây dựng một thuật toán sắpxếp cần chú ý tìm cách giảm thiểu những phép so sánh và đổi chổ không cần thiết để tăng hiệu quả của thuật toán. Đối với các dãy số được lưu trữ trong bộ nhớ chính, nhu cầu tiết kiệm bộ nhớ được đặt nặng, do vậy những thuật toán sắpxếp đòi hỏi cấp phát thêm vùng nhớ để lưu trữ dãy kết quả ngoài vùng nhớ lưu trữ dãy số ban đầu thường ít được quan tâm. Thay vào đó, các thuật toán sắpxếp trực tiếp trên dãy số ban đầu – gọi là các thuật toán sắpxếp tại chổ - lại được đầu tư phát triển. Phần này giới thiệu một số giải thuật sắpxếp từ đơn giản đến phức tạp có thể áp dụng thích hợp cho việc sắpxếp nội. 6 Bài tập chủ đề lớn 1 C. NỘI DUNG CỦA CÁCPHƯƠNGPHÁPSẮPXẾP I. Phươngpháp chọn trực tiếp (Selection sort): 1. Giải thuật: - Phươngphápsắpxếp chọn trực tiếp - selection sort là phươngphápsắpxếpbằng cách chọn phần tử nhỏ nhất xếp vào vị trí thứ nhất, tương tự các phần tử nhỏ tiếp theo xếp vào vị trí tiếp theo lần lượt cho đến hết số phầm tử trong dãy.Ta thấy rằng, nếu mảng có thứ tự, phần tử a i luôn là min(a i , a i+1 , , a n-1 ). Ý tưởng của thuật toán chọn trực tiếp mô phỏng một trong những cách sắpxếp tự nhiên nhất trong thực tế: chọn phần tử nhỏ nhất trong n phần tử ban đầu, đưa phần tử này về vị trí đúng là đầu dãy hiện hành; sau đó không quan tâm đến nó nữa, xem dãy hiện hành chỉ còn n – 1 phần tử của dãy ban đầu, bắt đầu từ vị trí thứ hai; lặp lại quá trình trên cho dãy hiện hành … đến khi dãy hiện hành chỉ còn một phần tử. Dãy ban đầu còn n phần tử, vậy tóm tắt ý tưởng thuật toán là thực hiện n-1 lượt việc đưa phần tử nhỏ nhất trong dãy hiện hành về vị trí đúng ở đầu dãy. - Các bước tiến hành như sau : + Bước 1: Gán i bằng 1 (i:=1,bắt đầu từ phần tử đầu tiên của dãy); + Bước 2: Tìm phần tử a[min] nhỏ nhất trong dãy tiến hành từ a[i] đến a[n]. + Bước 3: Hoán vị a[min] và a[i]. + Bước 4: Nếu i < n-1 thì i := i + 1; Lặp lại Bước 2. Ngược lại: Dừng.( n-1 phần tử đã nằm đúng vị trí ). - Ví dụ : Cho dãy số a : 12 2 8 5 1 6 4 15 7 12 2 8 5 1 6 4 15 Bài tập chủ đề lớn 1 8 I=1 1 2 8 5 12 6 4 15 1 2 8 5 12 6 4 15 I=3 1 2 4 5 12 6 8 15 I=4 1 2 4 5 12 6 8 15 I=5 1 2 4 5 6 12 8 15 I=6 1 2 4 5 6 8 12 15 I=7 I=2 Bài tập chủ đề lớn 1 2. Đánh giá giải thuật: - Đối với giải thuật chọn trực tiếp, có thể thấy rằng ở lượt thứ i, bao giờ cũng cần ( n-1) lần so sánh để xác định phần tử nhỏ nhất hiện hành. Số lượng phép so sánh này không phụ thuộc vào tình trạng của dãy số ban đầu, do vậy trong mọi trường hợp có thể kết luận : Số lần so sánh bằng = 2 )1( )( 1 1 − =− ∑ − = nn in n i - Số lần hoán vị ( một hoán vị bằng 3 phép gán ) lại phụ thuộc vào tình trạng ban đầu của dãy số, ta chỉ có thể ước lược trong từng trường hợp như sau: Trường hợp Số lần so sánh Số phép gán Tốt nhất n(n-1)/2 0 Xấu nhất n(n-1)/2 3n(n-1)/2 3. Lưu đồ thuật toán : Xem như dãy số cần sắpxếp đã được nhập vào sẵn 9 Begin Đổi chổ a[j] & a[j-1]; i = 1 j = n j >= i+1 i<=n- 1 Đúng Sai Sai En d a[j]<a[j- 1] Đúng Đúng Sai Xuất dãy số 12 Bài tập chủ đề lớn 1 II. Phươngpháp chèn trực tiếp (Insert sort): 1. Giải thuật: Giả sử có một dãy a 1 , a 2 , …, a i-1 đã có thứ tự. Ý tưởng của giải thuật sắpxếpbằngphươngpháp chèn trực tiếp là tìm cách chèn phần tử a i vào vị trí thích hợp của đoạn đã được sắpxếpđể được dãy mới a 1 , a 2 , …, a i trở nên có thứ tự. Vị trí này chính là vị trí giữa hai phần tử a k-1 và a k thỏa a k-1 < a i < a k Cho dãy ban đầu a 1 , a 2 , …, a n ta có thể xem như đã có đoạn gồm một phần tử a 1 đã được sắp xếp, sau đó thêm a 2 vào đoạn a 1 sẽ có đoạn a 1 , a 2 được sắp xếp; tiếp tục thêm a 3 vào đoạn a 1 , a 2 để có đoạn a 1 , a 2 , a 3 được sắp; tiếp tục cho đến khi thêm xong a N vào đoạn a 1 a 2 , …a N-1 sẽ có dãy a 1 a 2 … a N được sắp. - Các bước tiến hành như sau: + Bước 1: i = 2; (giả sử có đoạn a[1] được sắp) + Bước 2: x:= a[i]; tìm vị trí pos thích hợp trong đoạn a[1] để chèn a[i] vào; + Bước 3: Dời chổ các phần tử từ a[pos đến a[i-1] sang phải một vị trí để dành chổ cho a[i]; + Bước 4: a[pos] := x; (có đoạn a[1]…a[i] đã được sắp) + Bước 5: i := i+1 ; nếu i < n : lặp lại bước 2. Ngược lại : Dừng - Ví dụ : Xét dãy số gồm các số hạng : 12 2 8 5 1 6 4 15 10 12 2 8 5 1 6 4 15 2 12 8 5 1 6 4 15 I=2 I=3 2 8 12 5 1 6 4 15