Bài giảng Thuật toán ứng dụng - Bài 1 - Đỗ Tuấn Anh

Duyệt kết quả của bài toán từ nhỏ đến lớn, cố định số trang sách lớn nhất được chia cho 1 người. Với mỗi kết quả ta đi kiểm tra xem có thể chia được cho đúng k người hay không bằng thuật toán tham lam. In ra kết quả ngay khi tìm được kết quả thỏa mãn Độ phức tạp thuật toán O(MAX ∗ n) Gọi maxVal là số trang lớn nhất được chia bởi 1 người. Nhận thấy nếu với giá trị maxVal = x có thể chia dãy thành ≤ k đoạn thì với maxVal = x + 1 cũng có thể chia dãy thành ≤ k đoạn với cách chia như cũ. Ta chặt nhị phân giá trị maxVal. Độ phức tạp thuật toán O(log MAX ∗ n)

pdf20 trang | Chia sẻ: hachi492 | Ngày: 06/01/2022 | Lượt xem: 402 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Bài giảng Thuật toán ứng dụng - Bài 1 - Đỗ Tuấn Anh, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
PIE EKO BOOK1 Thuật toán ứng dụng Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng Viện Công Nghệ Thông Tin và Truyền Thông Trường Đại học Bách Khoa Hà Nội Tháng 4, năm 2020 Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 1 / 20 PIE EKO BOOK1 Mục lục 1 PIE 2 EKO 3 BOOK1 Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 2 / 20 PIE EKO BOOK1 PIE Lớp bài toán phân chia công bằng Vấn đề đặt ra là nguồn tài nguyên không đồng nhất Ví dụ : Đối với nguồn tài nguyên không phân chia được Tài sản thừa kế Phân bổ dụng cụ Phân bổ nguồn lực Đối với Những tài nguyên có thể cắt được Bài toán chia bánh Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 3 / 20 PIE EKO BOOK1 Phát biểu bài toán Có N cái bánh và F + 1 người. Bánh thứ i có bán kính ri và chiều cao là 1. Mỗi người chỉ được nhận một miếng bánh từ một chiếc bánh. Cần chia bánh sao cho mọi người có lượng bánh bằng nhau (có thể bỏ qua vụn bánh). Tìm lượng bánh lớn nhất mỗi người nhận được. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 4 / 20 PIE EKO BOOK1 Ví dụ Giả sử có 3 cái bánh có bán kính lần lượt là 2;1;1.5 Cần chia 3 cái bánh trên cho 7 người Cách chia sau là tối ưu, mỗi người nhận được một phần là pi Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 5 / 20 PIE EKO BOOK1 Thuật toán Gọi p[i] là số người ăn chiếc bánh thứ i . Lượng bánh mỗi người nhận được là mini{V [i]p[i] } với V [i] là thể tích của chiếc bánh thứ i . Cách 1 - Tìm kiếm theo mảng p : Tìm kiếm vét cạn mọi giá trị của p. Cách 2 - Tìm kiếm theo lượng bánh mỗi người nhận được : Thử từng kết quả, với mỗi kết quả, kiểm tra xem có thể chia bánh cho tối đa bao nhiêu người. Tối ưu cách 2 : Sử dụng thuật toán tìm kiếm nhị phân để tìm kiếm kết quả. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 6 / 20 PIE EKO BOOK1 Code 1 sort(r, r + N); 2 3 double lo = 0, hi = 4e8, mi; 4 5 for(int it = 0; it < 100; it++){ 6 mi = (lo + hi) / 2; 7 8 int cont = 0; 9 10 for(int i = N - 1;i >= 0 && cont <= F; --i) 11 cont += (int) 12 floor(PI * r[i] * r[i] / mi); 13 14 if(cont > F) lo = mi; 15 else hi = mi; 16 } 17 printf("%0.6f", low); Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 7 / 20 PIE EKO BOOK1 EKO Cho n cái cây có chiều cao khác nhau a1,a2, ...an Có thể thực hiện một phát cắt độ cao h với tất cả các cây. Số lượng gỗ thu được là phần chóp của các cây cao hơn h. Tìm h lớn nhất có thể để số lượng gỗ thu được lớn hơn m. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 8 / 20 PIE EKO BOOK1 Phát biểu bài toán Cho n cái cây có chiều cao khác nhau a1,a2, ...an Có thể thực hiện một phát cắt độ cao h với tất cả các cây. Số lượng gỗ thu được là phần chóp của các cây cao hơn h. Tìm h lớn nhất có thể để số lượng gỗ thu được lớn hơn m. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 9 / 20 PIE EKO BOOK1 Ví dụ Có 4 cây 20,15,10,17, lượng gỗ tối thiểu cần cắt là 7. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 10 / 20 PIE EKO BOOK1 Ví dụ Chọn h = 15→ số lượng gỗ thu được ở mỗi cây là 5,0,0,2. tổng là 7. Vậy chiều cao lớn nhất có thể cắt được là 15 Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 11 / 20 PIE EKO BOOK1 Thuật toán Thuật toán 1 : tìm tất cả các giá trị h ∈ {0,max(a[i])}. Với mỗi h, tính số lượng gỗ thu được. ĐPT : O(max(a[i]) ∗ n). Thuật toán 2 : chặt nhị phân giá trị h. Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 12 / 20 PIE EKO BOOK1 Code 18 long long count_wood(int height) { 19 long long sum = 0; 20 for (int i = 1; i <= n; i++) 21 if ( a[i] > height ) 22 sum += a[i] - height; 23 return sum; 24 } 25 26 int main { 27 int l = 0, r = max(r,a[i]); 28 29 while (r - l > 1) { 30 int mid = (l + r) / 2; 31 if (count_wood(mid) >= m ) l = mid; 32 else r = mid; 33 } 34 cout << l; 35 } Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 13 / 20 PIE EKO BOOK1 BOOKS1 Có m quyển sách, quyển sách thứ i dày pi trang. Phải chia số sách trên cho đúng k người, mỗi người sẽ nhận được một đoạn sách liên tiếp nhau. In ra cách chia để số trang sách lớn nhất được nhận bởi một người là nhỏ nhất. Nếu có nhiều kết quả lớn nhất thì ưu tiên số sách nhận bởi người 1 là ít nhất, sau đó đến người 2, ... Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 14 / 20 PIE EKO BOOK1 Ví dụ Đầu vào có 5 quyển sách và phải chia số sách trên cho 3 người Mỗi quyển sách có độ dày như hình bên Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 15 / 20 PIE EKO BOOK1 Ví dụ Kết quả của bài toán là 4 Có 2 cách chia để đạt được kết quả trên : 1 2/1 3/4 hoặc 1 2 1/3/4 Cách chia như hình bên là kết quả của bài toán Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 16 / 20 PIE EKO BOOK1 Thuật toán 1 Duyệt kết quả của bài toán từ nhỏ đến lớn, cố định số trang sách lớn nhất được chia cho 1 người. Với mỗi kết quả ta đi kiểm tra xem có thể chia được cho đúng k người hay không bằng thuật toán tham lam. In ra kết quả ngay khi tìm được kết quả thỏa mãn Độ phức tạp thuật toán O(MAX ∗ n) Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 17 / 20 PIE EKO BOOK1 Code 1 36 bool check(long long max_val) { 37 vector pos; 38 long long sum = 0; 39 for (int i = n; i >= 1; i--) { 40 if (sum + a[i] <= max_val) { 41 sum += a[i]; 42 } else { 43 sum = a[i]; 44 if (a[i] > max_val) { return false; } 45 pos.push_back(i); // cac phan tu ngan cach 46 } 47 } 48 if (pos.size() >= k) { return false; } 49 ** In ket qua ** 50 return true; 51 } Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 18 / 20 PIE EKO BOOK1 Thuật toán 2 Gọi maxVal là số trang lớn nhất được chia bởi 1 người. Nhận thấy nếu với giá trị maxVal = x có thể chia dãy thành ≤ k đoạn thì với maxVal = x + 1 cũng có thể chia dãy thành ≤ k đoạn với cách chia như cũ. Ta chặt nhị phân giá trị maxVal . Độ phức tạp thuật toán O(logMAX ∗ n) Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 19 / 20 PIE EKO BOOK1 Code 2 52 bool check(long long max_val) { 53 // Giong voi ham o Code 1 54 } 55 int main() { 56 int q; cin >> q; 57 while (q--) { 58 cin >> n >> k; 59 for (int i = 1; i > a[i]; } 60 long long l = 0, r = MAX; 61 while (r - l > 1) { 62 long long mid = (l + r) >> 1; 63 if (check(mid)) { 64 r = mid; 65 } else { 66 l = mid; 67 } 68 } 69 ** In kq tuong ung voi gia tri r ** 70 } 71 } Giảng viên : Đỗ Tuấn Anh, Lê Quốc Trung TA: Trần Thanh Tùng HUSTThuật toán ứng dụng Tháng 4, năm 2020 20 / 20

Các file đính kèm theo tài liệu này:

  • pdfbai_giang_thuat_toan_ung_dung_bai_1_do_tuan_anh.pdf