tailieunhanh - Cấu trúc dữ liệu và giải thuật - Chương 2.2: Giải thuật sắp xếp

Xác định được vai trò của tìm kiếm và sắp xếp trong hệ thống thông tin Nắm vững và minh họa được giải thuật tìm kiếm tuyến tính và tìm kiếm nhị phân trên mảng một chiều Cài đặt được giải thuật tìm kiếm bằng ngôn ngữ C/C++ | Chương . Giải thuật sắp xếp Nắm vững, minh họa và tính toán được các phép gán (hoán vị) các giải thuật sắp xếp cơ bản trên mảng một chiều Cài đặt được các giải thuật bằng ngôn ngữ C/C++ Sắp xế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 một 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ử. Khái niệm nghịch thế Giả sử xét mảng có thứ tự tăng dần, nếu có iaj thì ta gọi đó là nghịch thế. Mục tiêu của sắp xếp là khử các nghịch thế (bằng cách hoán vị) a1 a2 a3 a4 aN-2 aN-1 aN Đổi chổ trực tiếp – Interchange Sort Chọn trực tiếp – Selection Sort Chèn trực tiếp – Insertion Sort Quick Sort Nổi bọt – Buble Sort Một số giải thuật khác đọc thêm trong tài liệu Ý tưởng Ý tưởng chính của giải thuật là xuất phát từ đầu dãy, tìm tất cả nghịch thế chứa phần tử này, triệt tiêu chúng bằng cách đổi chỗ phần tử này với phần tử tương ứng trong cặp nghịch thế. Lặp lại xử lý trên với các phần tử tiếp theo trong dãy. 1 2 3 4 5 6 7 8 Giả sử cần sắp xếp dãy số sau tăng dần 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j 1 2 3 4 5 6 7 8 Bước 1: Xét phần tử đầu tiên (tại vị trí 1) i j Kết thúc bước 1 1 2 3 4 5 6 7 8 Bước 2: Xét phần tử thứ hai (tại vị trí 2) i j 1 2 3 4 5 6 7 8 Bước 2: Xét phần tử thứ hai (tại vị trí 2) i j 1 2 3 4 5 6 7 8 Bước 2: Xét phần tử thứ hai (tại vị trí 2) i j 1 2 3 4 5 6 7 8 Bước 2: Xét phần tử thứ hai (tại vị trí 2) i j 1 2 3 4 5 6 7 8 Bước 2: Xét phần tử thứ hai (tại vị trí 2) i j 1 2 3 4 5 6 7 8 | Chương . Giải thuật sắp xếp Nắm vững, minh họa và tính toán được các phép gán (hoán vị) các giải thuật sắp xếp cơ bản trên mảng một chiều Cài đặt được các giải thuật bằng ngôn ngữ C/C++ Sắp xế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 một 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ử. Khái niệm nghịch thế Giả sử xét mảng có thứ tự tăng dần, nếu có iaj thì ta gọi đó là nghịch thế. Mục tiêu của sắp xếp là khử các nghịch thế (bằng cách hoán vị) a1 a2 a3 a4 aN-2 aN-1 aN Đổi chổ trực tiếp – Interchange Sort Chọn trực tiếp – Selection Sort Chèn trực tiếp – Insertion Sort Quick Sort Nổi bọt – Buble Sort Một số giải thuật khác đọc thêm trong tài liệu Ý tưởng Ý tưởng chính của giải thuật là xuất phát từ đầu dãy, tìm tất cả nghịch thế chứa phần tử này, triệt tiêu chúng bằng cách đổi chỗ phần tử này với phần tử tương ứng trong cặp nghịch thế. Lặp lại xử lý trên với các .