intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2.2 – Trần Minh Thái (2017)

Chia sẻ: Nguoibakhong01 Nguoibakhong01 | Ngày: | Loại File: PPTX | Số trang:124

50
lượt xem
3
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Bài giảng Cấu trúc dữ liệu và giải thuật - Chương 2.2: Giải thuật sắp xếp" được biên soạn nhằm giúp người học có thể: 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.

Chủ đề:
Lưu

Nội dung Text: Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2.2 – Trần Minh Thái (2017)

  1. Chương 2.2. Giải thuật sắp xếp Trần Minh Thái Email: minhthai@huflit.edu.vn Website: www.minhthai.edu.vn  1
  2. Mục tiêu  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 2
  3. Các khái niệm  Để truy xuất thông tin nhanh chóng và chính xác  thông tin phải được sắp xếp theo một trật tự hợp lý nào đó  Một số CTDL đã định nghĩa trước trật tự của các phần tử, khi đó mỗi phần tử khi thêm vào phải đảm bảo trật tự này  Sắp xếp là quá trình xử lý một danh 3 sách các
  4. Khái niệm  Tương tự như các giải thuật tìm kiếm, khối lượng công việc phải thực hiện có liên quan chặt chẽ với số lần so sánh các khóa  Ngoài ra, các giải thuật sắp xếp còn phải di chuyển các phần tử  Chiếm nhiều thời gian khi các phần tử có kích thước lớn 4
  5. Các khái niệm  Khái niệm nghịch thế a0 a1 a2 a3 … … an- an- An- 3 2 1 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ị) 5
  6. Các giải thuật sắp xếp cơ bản  Đổi chỗ trực tiếp – Interchange Sort  Chọn trực tiếp – Selection Sort  Chèn trực tiếp – Insertion Sort  Nổi bọt – Bubble Sort  Quick Sort  Một số giải thuật khác đọc thêm trong tài liệu 6
  7. Đổi chỗ trực tiếp – interchange sort Ý tưởng  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ỗ (hoán vị)  Lặp lại xử lý trên với các phần tử tiếp theo trong dãy. 7
  8. Đổi chỗ trực tiếp – interchange sort Giả sử cần sắp xếp dãy số sau tăng dần 15 10 9 5 7 3 2 1 0 1 2 3 4 5 6 7 8
  9. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 5 7 3 2 1 0 1 2 3 4 5 6 7 9 i j
  10. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 5 7 3 2 1 0 1 2 3 4 5 6 7 10 i j
  11. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 5 7 3 2 1 0 1 2 3 4 5 6 7 11 i j
  12. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 7 5 3 2 1 0 1 2 3 4 5 6 7 12 i j
  13. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 7 5 3 2 1 0 1 2 3 4 5 6 7 13 i j
  14. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 7 5 2 3 1 0 1 2 3 4 5 6 7 14 i j
  15. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) 15 10 9 7 5 2 3 1 0 1 2 3 4 5 6 7 15 i j
  16. Đổi chỗ trực tiếp – interchange sort Bước 1: Xét phần tử đầu tiên (tại vị trí 0) Kết thúc bước 1 15 10 9 7 5 1 3 2 0 1 2 3 4 5 6 7 16 i j
  17. Đổi chỗ trực tiếp – interchange sort Bước 2: Xét phần tử thứ hai (tại vị trí 1) 15 10 9 7 5 1 3 2 0 1 2 3 4 5 6 7 17 i j
  18. Đổi chỗ trực tiếp – interchange sort Bước 2: Xét phần tử thứ hai (tại vị trí 1) 15 10 9 7 5 1 3 2 0 1 2 3 4 5 6 7 18 i j
  19. Đổi chỗ trực tiếp – interchange sort Bước 2: Xét phần tử thứ hai (tại vị trí 1) 15 10 9 5 7 1 3 2 0 1 2 3 4 5 6 7 19 i j
  20. Đổi chỗ trực tiếp – interchange sort Bước 2: Xét phần tử thứ hai (tại vị trí 1) 15 10 9 5 7 1 3 2 0 1 2 3 4 5 6 7 20 i j
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2