Giải thuật chia để trị (divide and conquer)
Giải thuật chia để trị (Divide and Conquer) là gì?
Phương pháp chia để trị (Divide and Conquer) là một phương pháp quan trọng trong việc thiết kế các giải thuật. Ý tưởng của phương pháp này khá đơn giản và rất dễ hiểu: Khi cần giải quyết một bài toán, ta sẽ tiến hành chia bài toán đó thành các bài toán con nhỏ hơn. Tiếp tục chia cho đến khi các bài toán nhỏ này không thể chia thêm nữa, khi đó ta sẽ giải quyết các bài toán nhỏ nhất này và cuối cùng kết hợp giải pháp của tất cả các bài toán nhỏ để tìm ra giải pháp của bài toán ban đầu.

Nói chung, bạn có thể hiểu giải thuật chia để trị (Divide and Conquer) qua 3 tiến trình sau:
Tiến trình 1: Chia nhỏ (Divide/Break)
Trong bước này, chúng ta chia bài toán ban đầu thành các bài toán con. Mỗi bài toán con nên là một phần của bài toán ban đầu. Nói chung, bước này sử dụng phương pháp đệ qui để chia nhỏ các bài toán cho đến khi không thể chia thêm nữa. Khi đó, các bài toán con được gọi là "atomic – nguyên tử", nhưng chúng vẫn biểu diễn một phần nào đó của bài toán ban đầu.
Tiến trình 2: Giải bài toán con (Conquer/Solve)
Trong bước này, các bài toán con được giải.
Tiến trình 3: Kết hợp lời giải (Merge/Combine)
Sau khi các bài toán con đã được giải, trong bước này chúng ta sẽ kết hợp chúng một cách đệ qui để tìm ra giải pháp cho bài toán ban đầu.
Hạn chế của giải thuật chia để trị (Devide and Conquer)
Giải thuật chia để trị tồn tại hai hạn chế, đó là:
Làm thế nào để chia tách bài toán một cách hợp lý thành các bài toán con, bởi vì nếu các bài toán con được giải quyết bằng các thuật toán khác nhau thì sẽ rất phức tạp.
Việc kết hợp lời giải các bài toán con được thực hiện như thế nào.
Ví dụ giải thuật chia để trị
Dưới đây là một số giải thuật được xây dựng dựa trên phương pháp chia để trị (Divide and Conquer):
- Giải thuật sắp xếp trộn (Merge Sort)
- Giải thuật sắp xếp nhanh (Quick Sort)
- Giải thuật tìm kiếm nhị phân (Binary Search)
- Nhân ma trận của Strassen
Theo Tutorialspoint
Bài trước: Giải thuật tham lam (Greedy Algorithm)
Bạn nên đọc
-
Diện tích hình trụ: Diện tích xung quanh hình trụ, diện tích toàn phần hình trụ
-
Công thức tính diện tích hình hộp chữ nhật
-
Công thức tính diện tích mặt cầu, thể tích khối cầu
-
Công thức tính chu vi hình tứ giác, diện tích hình tứ giác
-
Công thức tính diện tích hình thoi, chu vi hình thoi
-
Công thức tính diện tích hình bình hành, chu vi hình bình hành
Theo Nghị định 147/2024/ND-CP, bạn cần xác thực tài khoản trước khi sử dụng tính năng này. Chúng tôi sẽ gửi mã xác thực qua SMS hoặc Zalo tới số điện thoại mà bạn nhập dưới đây:
-
Code NgầuThích · Phản hồi · 1 · 17/08/20 -
Code NgầuThích · Phản hồi · 0 · 17/08/20
Cũ vẫn chất
-

Cách cài đặt các codec HEVC miễn phí trên Windows 10 (cho video H.265)
2 ngày -

Ngày đẹp khai xuân 2024, ngày tốt khai trương đầu năm 2024
2 ngày -

Cách trồng hành tây trong cốc nước vừa trang trí vừa giúp giảm stress
2 ngày -

Cách kiểm tra lịch sử trên máy tính để biết có ai đó đã truy cập và sử dụng máy tính của bạn?
2 ngày -

Cách đổi dấu phẩy thành dấu chấm trên Word
2 ngày -

Cách download Windows 10, tải file ISO Windows 10 từ Microsoft
2 ngày 20 -

Tại sao nên thay đổi vị trí tải xuống mặc định trong Windows 11?
2 ngày -

Stt thay đổi bản thân, cap thay đổi bản thân tạo động lực trong cuộc sống
2 ngày -

Xóa tận gốc các file "cứng đầu" nhất trên Windows
2 ngày -

Hướng dẫn đổi code Untitled Boxing game
2 ngày
Học IT
Lập trình
Microsoft Word 2013
Microsoft Word 2007
Microsoft Excel 2019
Microsoft Excel 2016
Microsoft PowerPoint 2019
Google Sheets
Lập trình Scratch
Bootstrap
Prompt
Ô tô, Xe máy