(SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

19 8 0
(SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên SỞ GIÁO DỤC VÀ ĐÀO TẠO LÀO CAI TRƢỜNG THPT CHUYÊN TỈNH LÀO CAI - - SÁNG KIẾN KINH NGHIỆM ỨNG DỤNG PHƢƠNG PHÁP QHĐ VÀO GIẢI QUYẾT MỘT SỐ BÀI TOÁN TRONG TIN HỌC HỌ TÊN GIÁO VIÊN: MAI HỒNG KIÊN Đơn vị: Tổ Toán - tin Năm học 2013 – 2014 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên MỤC LỤC Nội dung Đặt vấn đề Giải vấn đề 2.1 Cơ sở lý luận 2.2 Thực trạng vấn đề 2.3 Các biện pháp thực giải vấn đề 2.3.1 Áp dụng phương pháp QHĐ 2.3.2 Ví dụ minh họa 2.3.3 Một số toán tối ưu giải phương pháp QHĐ 2.4 Hiệu SKNN Kết luận Tài liệu tham khảo Trang 4 16 17 17 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Đặt vấn đề - Sự phát triển vũ bão Cơng nghệ Thơng tin Truyền thơng đóng vai trị không nhỏ phát triển chung nhân loại Đảng nhà nước xác định rõ ý nghĩa tầm quan trọng tin học, Công nghệ Thông tin Truyền thông yêu cầu đẩy mạnh ứng dụng Công nghệ Thông tin, đào tạo hệ trẻ động, sáng tạo, nắm vững tri thức khoa học cơng nghệ để làm chủ hồn cảnh công tác hoạt động xã hội thời kỳ cơng nghiệp hóa đại hóa đất nước - Chính xác định tầm quan trọng nên nhà nước đưa môn tin học vào nhà trường từ tiểu học học sinh tiếp xúc môn tin học để làm quen dần với lĩnh vực cơng nghệ thơng tin, tạo móng ban đầu để học phần nâng cao - Trong chương trình Tin học THPT lớp 10 học sinh giới thiệu kiến thức đại cương tin học, lớp 11 học sinh giới thiệu lập trình, lớp 12 học sinh học sở liệu Trong chương trình Tin học THPT chương trình lớp 11 phần cho khó nhất, học sinh phải làm quen với ngơn ngữ lập trình Pascal nắm số thuật tốn Chương trình tin học lớp 11 nhằm rèn luyện tư thuật toán cho học sinh, rèn luyện kĩ lập trình, tính kiên trì, tỉ mỉ cẩn thận - Tuy nhiên từ thực tiễn giảng dạy học sinh đại trà học sinh đội tuyển tin học trường THPT chuyên Lào Cai thấy rằng, học sinh gặp khó khăn chuyển lời giải tốn từ tốn sang ngơn ngữ lập trình Đặc biệt việc phân tích tốn, nhận biết tốn giải phương pháp nào, cỏ lời giải tối ưu hay không ? Xuất phát từ sở trên, chọn đề tài “Áp dụng phương pháp quy hoạch động để giải toán tối ưu tin học”, giúp học sinh nắm phương pháp quy hoạch động giải toán tối ưu tin học LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Giải vấn đề 2.1 Cơ sở lí luận - Nguyên lý tối ƣu Bellman Phương pháp quy hoạch động nguyên lý tối ưu nhà toán học Mỹ R.Bellman đề xuất vào năm 50 kỷ 20 Phương pháp áp dụng để giải hàng loạt tốn thực tế q trình kỹ thuật cộng nghệ, tổ chức sản xuất, kế hoạch hoá kinh tế… Trong thực tế, ta thường gặp số toán tối ưu loại sau: Có đại lượng f hình thành trình gồm nhiều giai đoạn ta quan tâm đến kết cuối giá trị f phải lớn nhỏ nhất, ta gọi chung giá trị tối ưu f Giá trị f phụ thuộc vào đại lượng xuất toán mà giá trị chúng gọi trạng thái hệ thống phụ thuộc vào cách thức đạt giá trị f giai đoạn mà cách tổ chức gọi điều khiển Đại lượng f thường gọi hàm mục tiêu trình đạt giá trị tối ưu f gọi trình điều khiển tối ưu Bellman phát biểu nguyên lý tối ưu (cũng gọi nguyên lý Bellman) mà ý tưởng sau: “Với trình điều khiển tối ưu, trạng thái bắt đầu A0, với trạng thái A trình đó, phần q trình kể từ trạng thái A xem trạng thái bắt đầu tối ưu” Chú ý nguyên lý thừa nhận mà không chứng minh Phương pháp tìm điều khiển tối ưu theo nguyên lý Bellman thường gọi quy hoạch động Thuật ngữ nói lên thực chất q trình điều khiển động: số bước lựa chọn điều khiển tối ưu dường khơng tốt tựu chung q trình lại tốt Hiểu cách đơn giản quy hoạch đ ng phương pháp giải toán từ nhỏ đến lớn, việc giải – tìm phương án tối ưu toán nhỏ lưu trữ kết LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên lại s giúp ta giải tốn với kích thước lớn dần đến đạt kết mong muốn 2.2 Thực trạng vấn đề Xét toán sau: Cho dãy N số ngun A1, A2,…,AN Hãy tìm cách xố số số hạng để dãy lại đơn điệu hay nói cách khác chọn số nhiều số hạng cho dãy B gồm số hạng theo trình tự xuất dãy A đơn điệu Quá trình chọn B điều khiển qua N giai đoạn để đạt mục tiêu số lượng số hạng dãy B nhiều nhất, điều khiển giai đoạn i thể việc chọn hay không chọn Ai vào dãy B Giả sử dãy cho 10 Nếu ta chọn 1, 8, 10 chọn số hạng bỏ qua 10 ta chọn số hạng 1, 2, 4, 6, Khi giải toán cách “chia để trị” chuyển việc giải toán kích thước lớn việc giải nhiều tốn kiểu có kích thước nhỏ thuật tốn thường thể chương trình đệ quy Khi đó, thực tế, nhiều kết trung gian phải tính nhiều lần Vậy ý tưởng quy hoạch động : Tránh tính tốn lại thứ hai lần, mà lưu giữ kết tìm kiếm vào m t bảng làm giả thiết cho việc tìm kiếm kết trường hợp sau Chúng ta s làm đầy dần giá trị bảng kết trường hợp trước giải Kết cuối kết tốn cần giải Nói cách khác phương pháp quy hoạch động thể sức mạnh nguyên lý chia để trị đến cao độ Quy hoạch đ ng kỹ thuật thiết kế bottom-up (từ lên) Nó bắt đầu với trường hợp nhỏ (thường đơn giải giải ngay) Bằng cách tổ hợp kết có (khơng phải tính lại) trường hợp con, đạt đạt LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên tới kết trường hợp có kích thước lớn dần lên tổng quát hơn, cuối đạt tới lời giải trường hợp tổng quát Trong số trường hợp, giải tốn A, trước hết ta tìm họ tốn A(p) phụ thuộc tham số p (có thể p véc tơ) mà A(p0)=A với p0 trạng thái ban đầu tốn A Sau tìm cách giải họ tốn A(p) với tham số p cách áp dụng nguyên lý tối ưu Bellman Cuối cho p=p s nhận kết toán A ban đầu 2.3 Các biện pháp thực giải vấn đề 2.3.1 Áp dụng phương pháp quy hoạch động Bước 1: Lập hệ thức Dựa vào nguyên lý tối ưu tìm cách chia trình giải tốn thành giai đoạn, sau tìm hệ thức biểu diễn tương quan định bước xử lý với bước xử lý trước Hoặc tìm cách phân rã tốn thành “bài tốn con” tương tự có kích thước nhỏ hơn, tìm hệ thức nêu quan hệ kết tốn kích thước cho với kết “bài tốn con” kiểu có kích thước nhỏ nhằm xây dựng phương trình truy tốn (dạng hàm thủ tục đệ quy) Về m t cách xây dựng phương trình truy tốn: Ta chia việc giải toán thành n giai đoạn Mỗi giai đoạn i có trạng thái ban đầu t(i) chịu tác động điều khiển d(i) s biến thành trạng thái t(i+1) giai đoạn i+1 (i=1,2,…,n-1) Theo nguyên lý tối ưu Bellman việc tối ưu giai đoạn cuối không làm ảnh hưởng đến kết tồn tốn Với trạng thái ban đầu t(n) sau làm giai đoạn n tốt ta có trạng thái ban đầu giai đoạn n-1 t(n-1) tác động điều khiển giai đoạn n-1 d(n-1), tiếp tục xét đến giai đoạn n-1 Sau tối ưu giai đoạn n-1 ta lại có t(n-2) d(n-2) lại tối ưu giai đoạn n-2 … giai đoạn từ n giảm đến tối ưu coi hồn thành tốn Gọi giá trị tối ưu tốn tính đến giai đoạn k Fk, giá trị tối ưu tốn tính riêng giai đoạn k Gk LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Fk = Fk-1 + Gk Hay là: F1 (t (k ))  m ax {G k (t (k ), d (k ))  Fk 1 (t (k  1))} (*) d ( k ) Bước 2: Tổ chức liệu chương trình Tổ chức liệu cho đạt yêu cầu sau:  Dữ liệu tính tốn dần theo bước  Dữ liệu lưu trữ để giảm lượng tính tốn lặp lại  Kích thước miền nhớ dành cho lưu trữ liệu nhỏ tốt, kiểu liệu chọn phù hợp, nên chọn đơn giản dễ truy cập Cụ thể  Các giá trị Fk thường lưu trữ bảng (mảng chiều hai, ba, v.v… chiều)  Cần lưu ý khởi trị giá trị ban đầu bảng cho thích hợp, kết tốn có kích cỡ nhỏ tốn giải: F1 (t (1))  m ax {G1 (t (1), d (1))  F0 (t (0))} d (1)  Dựa vào cơng thức, phương trình truy tốn (*) giá trị có bảng để tìm dần giá trị cịn lại bảng  Ngồi cịn cần mảng lưu trữ nghiệm tương ứng với giá trị tối ưu gian đoạn  Dựa vào bảng lưu trữ nghiệm bảng giá trị tối ưu giai đoạn xây dựng, tìm kết toán Bước 3: Làm tốt Làm tốt thuật toán cách thu gọn hệ thức (*) giảm kích thước miền nhớ Thường tìm cách dùng mảng chiều thay cho mảng hai chiều giá trị dòng (hoặc cột) mảng hai chiều phụ thuộc dòng (hoặc cột) kề trước LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Trong số trường hợp thay mảng hai chiều với giá trị phần tử nhận giá trị 0, mảng hai chiều cách dùng kỹ thuật quản lý bit 2.3.2 Ví dụ minh họa Cho số tự nhiên n ≤ 100 Hãy cho biết có cách phân tích số n thành tổng dãy số ngun dương, cách phân tích hốn vị tính m t cách n = có cách phân tích: = + + + + = + + + = + + = + + 5 = + = + = (Lưu ý: n = coi có cách phân tích thành tổng số nguyên dương (0 tổng dãy rỗng) Bước 1: Lập hệ thức Nhận xét: Nếu gọi F[m, v] số cách phân tích số v thành tổng số nguyên dƣơng ≤ m Khi đó: Các cách phân tích số v thành tổng số nguyên dương ≤ m chia làm hai loại: - Loại 1: Không chứa số m phép phân tích, số cách phân tích loại số cách phân tích số v thành tổng số nguyên dương < m, tức số cách phân tích số v thành tổng số nguyên dương ≤ m - F[m - 1, v] - Loại 2: Có chứa số m phép phân tích Khi cách phân tích loại ta bỏ số m ta s cách phân tích số v - m thành tổng số nguyên dương ≤ m (Lưu ý: điều khơng tính lặp lại LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chun hốn vị cách) Có nghĩa mặt số lượng, số cách phân tích loại F[m, v - m] Trong trường hợp m > v rõ ràng có cách phân tích loại 1, cịn trường hợp m ≤ v s có cách phân tích loại loại Vì thế: F[m 1, v]; if m > v F[m, v]=  F[m-1,v]+F[m,v-m]; if m  v Bước 2: Tổ chức liệu chương trình Ta có cơng thức xây dựng F[m, v] từ F[m - 1, v] F[m, v - m] Công thức có tên gọi cơng thức truy hồi đưa việc tính F[m, v] việc tính F[m', v'] với liệu nhỏ Tất nhiên cuối ta s quan tâm đến F[n, n]: Số cách phân tích n thành tổng số nguyên dương ≤ n Ví dụ với n = 5, bảng F s là: F V 0 0 1 1 1 1 2 3 1 1 1 m Nhìn vào bảng F, ta thấy F[m, v] tính tổng của: Một phần tử hàng trên: F[m - 1, v] phần tử hàng, bên trái: F[m, v - m] Cài đặt: program Analysis_Counting; const max = 100; var F: array[0 max, max] of Integer; n, m, v: Integer; LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên begin Write('n = '); ReadLn(n); FillChar(F[0], SizeOf(F[0]), 0); F[0, 0] := 1; for m := to n for v := to n if v < m then F[m, v] := F[m - 1, v] else F[m, v] := F[m - 1, v] + F[m, v - m]; WriteLn(F[n, n], ' Analyses'); end Bước 3: Làm tốt Cải tiến dùng mảng chiều Cách làm tóm tắt lại sau: Khởi tạo dịng bảng, sau dùng dịng tính dịng 1, dùng dịng tính dịng v.v… tới tính hết dịng n Có thể nhận thấy tính xong dịng thứ k việc lưu trữ dòng từ dòng tới dòng k - khơng cần thiết việc tính dịng k + phụ thuộc giá trị lưu trữ dịng k Vậy ta dùng hai mảng chiều: Mảng Current lưu dòng thời xét bảng mảng Next lưu dòng kế tiếp, mảng Current gán giá trị tương ứng dịng Sau dùng mảng Current tính mảng Next, mảng Next sau tính s mang giá trị tương ứng dòng Rồi lại gán mảng Current := Next tiếp tục dùng mảng Current tính mảng Next, mảng Next s gồm giá trị tương ứng dịng v.v… Vậy ta có cài đặt cải tiến sau: program Analysis_Counting_2; const max = 100; var Current, Next: array[0 max] of Integer; n, m, v: Integer; begin Write('n = '); ReadLn(n); FillChar(Current, SizeOf(Current), 0); Current[0] := 1; for m := to n begin for v := to n if v < m then Next[v] := Current[v] 10 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên else Next[v] := Current[v] + Next[v - m]; Current := Next; end; WriteLn(Current[n], ' Analyses'); end 2.3.3 Một số toán tối ƣu giải phƣơng pháp quy hoạch động Bài toán 1: Bài toán túi Trong siêu thị có n gói hàng (n ≤ 100), gói hàng thứ i có trọng lượng W[i] ≤ 100 trị giá V[i] ≤ 100 Một tên trộm đột nhập vào siêu thị, tên trộm mang theo túi mang tối đa trọng lượng M (M ≤ 100) Hỏi tên trộm s lấy gói hàng để tổng giá trị lớn Input: file văn BAG.INP - Dòng 1: Chứa hai số n, M cách dấu cách - n dòng tiếp theo, dòng thứ i chứa hai số nguyên dương W[i], V[i] cách dấu cách Output: file văn BAG.OUT - Dòng 1: Ghi giá trị lớn tên trộm lấy - Dịng 2: Ghi số gói bị lấy BAG.INP BAG.OUT 11 11 33 521 44 54 10 44 11 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Bài gi i: Nếu gọi F[i, j] giá trị lớn có cách chọn gói {1, 2, …, i} với giới hạn trọng lượng j Thì giá trị lớn chọn số n gói với giới hạn trọng lượng M F[n, M] Cơng thức truy hồi tính F[i, j] Với giới hạn trọng lượng j, việc chọn tối ưu số gói {1, 2, …, i - 1, i} để có giá trị lớn s có hai khả năng: o Nếu khơng chọn gói thứ i F[i, j] giá trị lớn cách chọn số gói {1, 2, …, i - 1} với giới hạn trọng lượng j Tức F[i, j] = F[i - 1, j] o Nếu có chọn gói thứ i (tất nhiên xét tới trường hợp mà W[i] ≤ j) F[i, j] giá trị gói thứ i V[i] cộng với giá trị lớn có cách chọn số gói {1, 2, …, i - 1} với giới hạn trọng lượng j - W[i] Tức mặt giá trị thu được: F[i, j] = V[i] + F[i - 1, j - W[i]] Vì theo cách xây dựng F[i, j] giá trị lớn có thể, nên F[i, j] s Max giá trị thu Cơ sở quy hoạch đ ng: Dễ thấy F[0, j] = giá trị lớn cách chọn số gói = Tính bảng phương án: Bảng phương án F gồm n + dòng, M + cột, trước tiên điền sở quy hoạch động: Dịng gồm tồn số Sử dụng cơng thức truy hồi, dùng dịng tính dịng 1, dùng dịng tính dịng 2, v.v… đến tính hết dịng n Truy vết Tính xong bảng phương án ta quan tâm đến F[n, M] giá trị lớn thu chọn n gói với giới hạn trọng lượng M Nếu F[n, M] = F[n 1, M] tức khơng chọn gói thứ n, ta truy tiếp F[n - 1, M] Cịn F[n, M] ≠ F[n 1, M] ta thơng báo phép chọn tối ưu có chọn gói thứ n truy tiếp F[n - 1, M W[n]] Cứ tiếp tục truy lên tới hàng bảng phương án program Bag; const 12 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên InputFile = 'BAG.INP'; OutputFile = 'BAG.OUT'; max = 100; var W, V: Array[1 max] of Integer; F: array[0 max, max] of Integer; n, M: Integer; procedure Enter; var i: Integer; fi: Text; begin Assign(fi, InputFile); Reset(fi); ReadLn(fi, n, M); for i := to n ReadLn(fi, W[i], V[i]); Close(fi); end; procedure Optimize; var i, j: Integer; begin FillChar(F[0], SizeOf(F[0]), 0); for i := to n for j := to M begin {Tính F[i, j]} F[i, j] := F[i - 1, j]; if (j >= W[i]) and (F[i, j] < F[i - 1, j - W[i]] + V[i]) then F[i, j] := F[i - 1, j - W[i]] + V[i]; end; end; procedure Trace; var fo: Text; begin Assign(fo, OutputFile); Rewrite(fo); WriteLn(fo, F[n, M]); while n begin if F[n, M] F[n - 1, M] then begin Write(fo, n, ' '); M := M - W[n]; 13 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên end; Dec(n); end; Close(fo); end; begin Enter; Optimize; Trace; end Bài toán 2: Chia thưởng Cần chia hết m phần thưởng cho n học sinh theo thứ tự từ giỏi trở xuống cho bạn không nhận phần thưởng bạn xếp sau  m, n  70 Hãy tính số cách chia Thí dụ, với số phần thưởng m = 7, số học sinh n = s có 11 cách chia phần thưởng cho học sinh theo yêu cầu đầu Đó là: Phƣơng án 10 11     5 4 3 2 3 2 0 1 1 0 0 0 0 1 14 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Bài giải Lập hệ thức Gọi Chia(i, j) số cách chia i phần thưởng cho j học sinh, ta thấy: - Nếu khơng có học sinh (j = 0) khơng có cách chia (Chia = 0) - Nếu khơng có phần thưởng (i = 0) có cách chia (Chia(0,j) = - học sinh nhận phần thưởng) Ta quy ước Chia(0, 0) = - Nếu số phần thưởng số học sinh (i < j) phương án chia, từ học sinh thứ i + trở s không nhận phần thưởng nào: Chia(i, j) = Chia(i, i) i < j Ta xét tất phương án chia trường hợp i  j Ta tách phương án chia thành hai nhóm khơng giao dựa số phần thưởng mà học sinh đứng cuối bảng thành tích, học sinh thứ j, nhận: - Nhóm thứ gồm phương án học sinh thứ j khơng nhận thưởng, tức i phần thưởng chia cho j - học sinh đó, số cách chia, tức số phần tử nhóm s là: Chia(i, j - 1) - Nhóm thứ hai gồm phương án học sinh thứ j nhận thưởng Khi đó, học sinh đứng cuối bảng thành tích nhận thưởng học sinh khác s có thưởng Do thưởng nên ta bớt người phần thưởng (để họ lĩnh sau), số phần thưởng lại (i - j) s chia cho j học sinh Số cách chia s Chia(i - j, j) Tổng số cách chia cho trường hợp i  j s tổng số phần tử hai nhóm, ta có: Chia(i, j) = Chia(i, j - 1) + Chia(i - j, j) Tổng hợp lại ta có: 15 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Điều kiện i: số phần thưởng Chia(i, j) j: số học sinh j=0 Chia(i, j) = i = and j  Chia(i, j) = i } if i = then {i = 0; j > } Chia := else {i,j > } if i < j then {0 < i < j } Chia := Chia(i,i) else {i >= j > } Chia := Chia(i,j-1)+Chia(i-j,j); end; Phương án chạy chậm phát sinh nhiều lần gọi hàm trùng lặp Bảng liệt kê số lần gọi hàm Chia giải toán chia thưởng với bảy phần thưởng (m = 7) học sinh (n = 4) Thí dụ, hàm Chia(1,1) s gọi lần,… Tổng số lần gọi hàm Chia 79 79 lần gọi hàm để sinh kết 11 tốn 16 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên              1 9 6 0 5 1 3 1 2 0 1 0 1 1 Số lần gọi hàm Chia cục tính hàm Chia(7,4) Làm tốt Phương án dễ triển khai chương trình s chạy lâu Diễn tả đệ quy thường sáng, nhàn tản, thực s sinh tượng gọi lặp lại hàm đệ quy Cải tiến tránh lần gọi lặp Muốn tính sẵn giá trị hàm theo trị đầu vào khác điền vào mảng hai chiều cc Mảng cc mô tả sau: const MN = 70;{ gioi han tren cua m va n } j-1 j var cc: array[0 MN,0 MN] of longint; Ta quy ước cc[i, j] chứa số cách chia i phần thưởng cho j học sinh i-j i [i-j,j] [i,j-1] [i,j] Theo phân tích phương án 1, ta có:  cc[0, 0] = 1; cc[i, 0] = 0, với i:=1 m  cc[i, j] = cc[i, i], i < j  cc[i, j] = cc[i, j-1]+cc[i-j, j], i  j Từ ta suy quy trình điền trị vào bảng cc sau:  Khởi trị  cc[0,0 ]:= 1; 17 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên  với i := m: cc[i,0] := 0;  Điền bảng: Lần lượt điền theo c t j:= n Tại c t j ta đặt:  với i := j-1: cc[i,j] := cc[i,i];  với i := j m: cc[i,j] := cc[i,j-1]+cc[i-j,j]; Nhận kết quả: Sau điền bảng, giá trị cc[m, n] kết cần tìm Phƣơng án d ng mảng chiều: function Chia2(m,n: integer):longint; var i,j: integer; begin cc[0,0] := 1; for i := to m cc[i,0] := 0; for j := to n begin for i := to j-1 cc[i,j] := cc[i,i]; for i := j to m cc[i,j] := cc[i,j-1]+cc[i-j,j]; end; Chia2 := cc[m,n]; end; 2.4 Hiệu SKKN - Trong trình trao đổi, thảo luận, trình bày học sinh thể khả vận dụng, hiểu biết nên em tỏ hăng hái việc giơ tay phát biểu tranh luận - Đa số học sinh lớp 11Toán, 11A1 nắm “phương pháp quy hoạch đ ng” 100% học sinh đội tuyển nắm vận dụng tốt kĩ thuật - Kết đạt được: Trong năm học trước 2011-2012, 2012-2013 đội tuyển Tin học trường khơng có giải HSGQG đến năm học 2013-2014 đội tuyển Tin học trường đạt giải HSG cấp tỉnh có giải giải nhì 01 giải HSG Quốc gia 18 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Sáng kiến kinh nghiệm 2014 – Mai Hồng Kiên -THPT chuyên Kết luận Như nói trên, chìa khóa thuật toán quy hoạch động việc xây dựng toán mà ta gọi mảng quy hoạch động Mảng 1, nhiều chiều tùy thuộc vào lời giải toán phụ thuộc vào loại tham số Tiếp đến cách quy nạp thu gọn toán sau bước, tức khơng gian tốn (kích thước liệu) nhỏ lại, ta hoàn toàn giải tốn nhỏ (điểm dừng quy nạp) Bản chất công việc ta phải xây dựng lời giải toán qua tốn con, tức lập cơng thức truy hồi, dựa vào công thức truy hồi, ta s biết cần phải khởi tạo Trong phần trên, khảo sát số tốn dùng thuật tốn quy hoạch động để giải cách hiệu Những vấn đề liên quan đến tốn tìm phương án tối ưu để thực công việc chúng có chung tính chất đáp án tốt cho toán trì tốn trở thành phần toán lớn Thuật toán quy hoạch động thường áp dụng để giải toán tối ưu, tốn đếm, … Vì vậy, giới hạn kích thước liệu tốn tối ưu lớn việc sử dụng thuật toán khác (như duyệt, nhánh cận, ) có độ phức tạp thời gian lớn nghĩ đến thuật tốn quy hoạch động TÀI LIỆU THAM KHẢO 1.Sách giáo khoa tin học 11 Sách giáo viên tin học 11 Tài liệu giáo khoa chuyên tin Hồ Sĩ Đàm Hồ Sĩ Đàm Hồ Sĩ Đàm Chủ biên Chủ biên Chủ biên 19 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com ... phát từ sở trên, chọn đề tài ? ?Áp dụng phương pháp quy hoạch động để giải toán tối ưu tin học? ??, giúp học sinh nắm phương pháp quy hoạch động giải toán tối ưu tin học LUAN VAN CHAT LUONG download... vấn đề Giải vấn đề 2.1 Cơ sở lý luận 2.2 Thực trạng vấn đề 2.3 Các biện pháp thực giải vấn đề 2.3.1 Áp dụng phương pháp QHĐ 2.3.2 Ví dụ minh họa 2.3.3 Một số toán tối ưu giải phương pháp QHĐ 2.4... Giải vấn đề 2.1 Cơ sở lí luận - Nguyên lý tối ƣu Bellman Phương pháp quy hoạch động nguyên lý tối ưu nhà toán học Mỹ R.Bellman đề xuất vào năm 50 kỷ 20 Phương pháp áp dụng để giải hàng loạt toán

Ngày đăng: 17/10/2022, 14:55

Hình ảnh liên quan

Ví dụ với n= 5, bảng Fs là: - (SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

d.

ụ với n= 5, bảng Fs là: Xem tại trang 9 của tài liệu.
Cách làm trên có thể tóm tắt lại như sau: Khởi tạo dịng của bảng, sau đó dùng dịng 0 tính dịng 1, dùng dịng 1 tính dịng 2 v.v… tới khi tính được hết dịng n - (SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

ch.

làm trên có thể tóm tắt lại như sau: Khởi tạo dịng của bảng, sau đó dùng dịng 0 tính dịng 1, dùng dịng 1 tính dịng 2 v.v… tới khi tính được hết dịng n Xem tại trang 10 của tài liệu.
Phương án này chạy chậm vì phát sinh ra quá nhiều lần gọi hàm trùng lặp. Bảng dưới đây liệt kê số lần gọi hàm Chia khi giải bài toán chia thưởng với bảy phần thưởng  (m = 7) và 4 học sinh (n = 4) - (SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

h.

ương án này chạy chậm vì phát sinh ra quá nhiều lần gọi hàm trùng lặp. Bảng dưới đây liệt kê số lần gọi hàm Chia khi giải bài toán chia thưởng với bảy phần thưởng (m = 7) và 4 học sinh (n = 4) Xem tại trang 16 của tài liệu.
Từ đó ta suy ra quy trình điền trị vào bảng cc như sau: - (SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

ta.

suy ra quy trình điền trị vào bảng cc như sau: Xem tại trang 17 của tài liệu.
 Điền bảng: Lần lượt điền theo từng ct j:= 1..n. Tại mỗi ct j ta đặt: - (SKKN HAY NHẤT) áp dụng phương pháp QHĐ để giải quyết các bài toán tối ưu trong tin học

i.

ền bảng: Lần lượt điền theo từng ct j:= 1..n. Tại mỗi ct j ta đặt: Xem tại trang 18 của tài liệu.

Tài liệu cùng người dùng

Tài liệu liên quan