1. Trang chủ
  2. » Giáo Dục - Đào Tạo

MINH HỌA GIẢI BÀI TOÁN 8 QUÂN HẬU BẰNG THƯ VIỆN ĐỒ HỌA

26 2 0

Đ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

Thông tin cơ bản

Định dạng
Số trang 26
Dung lượng 837,49 KB

Nội dung

BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC NHA TRANG KHOA CÔNG NGHỆ THÔNG TIN MINH HỌA GIẢI BÀI TOÁN QUÂN HẬU BẰNG THƯ VIỆN ĐỒ HỌA Giảng viên hướng dẫn: ThS Đoàn Vũ Thịnh Sinh viên thực hiện: Lê Hoàng Nam Mã số sinh viên: 61133986 Khánh Hịa - 2021 TRƯỜNG ĐẠI HỌC NHA TRANG KHOA CƠNG NGHỆ THÔNG TIN BỘ MÔN HỆ THỐNG THÔNG TIN MINH HỌA GIẢI BÀI TOÁN QUÂN HẬU BẰNG THƯ VIỆN ĐỒ HỌA Giảng viên hướng dẫn: ThS Đoàn Vũ Thịnh Sinh viên thực hiện: Lê Hoàng Nam Mã số sinh viên: 61133986 Khánh Hòa - Tháng 12/2021 TRƯỜNG ĐẠI HỌC NHA TRANG Khoa: Công nghệ Thông tin PHIẾU THEO DÕI TIẾN ĐỘ VÀ ĐÁNH GIÁ BÁO CÁO THỰC TẬP CƠ SỞ Tên đề tài: MINH HỌA GIẢI BÀI TOÁN QUÂN HẬU BẰNG THƯ VIỆN ĐỒ HỌA Giảng viên hướng dẫn: ThS Đoàn Vũ Thịnh Sinh viên hướng dẫn: Lê Hồng Nam MSSV: 61133986 Khóa: 61 Ngành: Cơng nghệ Thông tin Lần Ngày Nội dung Nhận xét GVHD 7/12/2020 Nhận đề tài hướng dẫn định hướng giải vấn đề Sinh viên trình bày kế hoạch thực Sinh viên GVHD trao đổi nội dung đề tài Phân chia công việc theo thời gian cho phù hợp với yêu cầu 14/12/2020 Sinh viên trình bày việc mơ thuật tốn dựa kiến thức học môn kỹ thuật đồ họa kiến thức thu nhận từ Internet để minh họa toán đa dạng Sinh viên hiểu vấn đề cần phải thực có giải pháp cho vấn đề cụ thể Tuy nhiên trình bày cịn thiếu sót cần đầu tư thời gian cho thuật toán 21/12/2020 Sinh viên hồn thiện thuật tốn đề với liệu đầu vào nhập từ bàn phím Trình bày thuật tốn với trường hợp sai hướng khắc phục cho trường hợp Sinh viên hiểu nội dung thuật tốn với trường hợp hạn chế thuật toán chưa đủ Các chức khác phụ trợ cho việc minh họa tốn hồn thành 4/01/2021 Sinh viên nộp thảo báo Báo cáo trình bày chung cáo thực tập lần thứ tiến chung chưa vào cụ thể hành chỉnh sửa phân tích u cầu tốn, hình ảnh, bảng biểu chưa trình bày rõ ràng Cần hiệu chỉnh theo yêu cầu GVHD 11/01/2021 Sinh viên nộp thảo lần Sinh viên nộp thảo lần tiến hành chỉnh sửa Đã tìm hiểu thuật toán đầy đủ 18/1/2021 Sinh viên nộp thảo lần Sinh viên nghiêm túc chỉnh cuối sau chỉnh sửa sửa báo cáo theo định yêu cầu đề hướng GVHD Nhận xét chung (sau sinh viên hồn thành ĐA/KL): Điểm hình thức: …./10 Điểm nội dung: … /10 Điểm tổng kết: … /10 Đồng ý cho sinh viên: Được bảo vệ:  Khơng bảo vệ:  Khánh Hịa, ngày 20 tháng 01 năm 2021 Cán hướng dẫn (Ký ghi rõ họ tên) MỤC LỤC TÓM TẮT GIỚI THIỆU 1.1 Bài toán quân hậu: 1.2 Đệ quy: 1.3 Thuật toán quay lui: 1.4 Visual Studio Code thư viện Graphics: PHƯƠNG PHÁP NGHIÊN CỨU .8 2.1 Cài đặt Visual Studio Code thư viện graphics.h: 2.2 Sử dụng thuật toán quay lui giải toán: 10 2.2.1 Tạo biến chuẩn bị cho cài đặt thuật toán: 10 2.2.2 Cài đặt thuật toán quay lui đệ quy: 10 2.2.3 Toàn thuật toán quay lui: 13 2.3 Các hàm khác chương trình: 13 2.3.1 Hàm vebanco (vẽ bàn cờ): 13 2.3.2 Hàm menu ktramenu: 14 2.4 Hàm floodfill cách xác định vị trí quân cờ bàn cờ: 15 2.5 Hàm main: .16 KẾT QUẢ 17 KẾT LUẬN .23 TÀI LIỆU THAM KHẢO .24 TÓM TẮT Bài toán quân hậu toán logic kinh điển từ kỷ XIX Sau tổng quát biết đến nhiều với cách gọi toán xếp hậu (bài toán xếp n quân hậu bàn cờ n×n) Ở dạng tổng quát này, ta tìm hàng tỷ cách giải với điều kiện n đủ lớn Đây toán ứng dụng nhiều mục đích giải trí học tập Việc giải tốn với mơ tả theo cách trực quan đem đến nhìn sâu toán thuật toán cài đặt để giải toán Sử dụng đồ họa máy tính, lĩnh vực Cơng Nghệ Thơng Tin dùng để nghiên cứu sở toán học, thuật toán kĩ thuật tạo, hiển thị, sử dụng hình ảnh hiển thị máy tính Đây lựa chọn tối ưu để tạo nên góc nhìn trực quan Cùng với thuật toán quay lui đệ quy, thuật toán học tìm hiểu, báo cáo thể hiện, mơ tả, giải đáp kết luận tồn q trình giải tốn qn hậu máy tính Thơng qua báo cáo, người đọc xác định ý tưởng cách giải toán quân hậu, quy luật quy ước giải Biết cách cài đặt Visual Studio Code thư viện đồ họa Quan trọng nhất, người đọc có nhìn tổng quan thuật tốn quay lui đệ quy, hiểu cách thuật toán sử dụng để giải toán quân hậu Cùng với thơng tin liên quan đến đồ họa, hàm có thư viện GIỚI THIỆU 1.1 Bài toán quân hậu: Bài toán quân hậu đưa vào năm 1848 kỳ thủ Max Bezzel Bài toán yêu cầu xếp quân hậu (hoặc n quân hậu dạng tốn xếp hậu tổng qt) bàn cờ kích thước 8×8 (hoặc n×n dạng tốn xếp hậu tổng qt) Sao cho khơng có qn hậu “ăn” quân hậu khác cách di chuyển theo luật cờ vua Minh họa lời giải tốn qn hậu Hình thể lời giải quân hậu bàn cờ thể hình vng đen viền trắng ô cờ thể 64 hình vng viền trắng bên bàn cờ Các ô cờ tô màu xanh thể vị trí cờ đặt quân hậu thỏa mãn yêu cầu toán Một số lời giải số học có dạng dãy số: 1, 5, 8, 6, 3, 7, 2, Đánh số thứ tự phần tử dãy từ đến Số thứ tự Dãy số Các số dòng cột đánh số từ xuống dưới, từ trái sang phải theo cách đánh số ma trận Mỗi số thứ tự xem số cột vị trí cờ mà qn hậu đặt, số dãy số dịng cờ mà quân hậu đặt Từ đó, ký hiệu quân hậu nằm ô thứ j đứng cột thứ i Q[i,j], ta hiểu dãy số vị trí: (1,1), (2,5), (3,8), (4,6), (5,3), (6,7), (7,2), (8,4) 1.2 Đệ quy: Theo Wikipedia, tính chất (hoặc cấu trúc) gọi đệ quy lớp đối tượng phương pháp xác định việc xác định số trường hợp phương pháp đơn giản (thông thường một) sau xác định quy tắc đưa trường hợp phức tạp trường hợp đơn giản Trong lập trình, hiểu đơn giản, trình chạy chương trình (hàm, thủ tục), chương trình (hàm, thủ tục) gọi lại gọi đệ quy Với toán quân hậu này, đệ quy dùng sở thuật toán quay lui 1.3 Thuật toán quay lui: Quay lui thuật toán phát triển dựa đệ quy, thường xuyên dùng để giải toán thõa mãn ràng buộc (Các toán thỏa mãn ràng buộc tốn có lời giải đầy đủ, thứ tự phần tử khơng quan trọng Các toán bao gồm tập biến mà biến cần gán giá trị tùy theo ràng buộc cụ thể toán) Việc quay lui giúp ta thử tất tổ hợp để tìm tất lời giải Rất phù hợp cho toán toán quân hậu Ví dụ trường hợp quay lui: Xét ô cờ cột chưa xét (cột thứ 7) ta thấy tất ô cột khơng thỏa u cầu tốn qn hậu: Minh họa ví dụ quay lui tốn quân hậu Lúc thuật toán quay lui tiếp tục xét ô cờ khả thi cột (ô thứ 6, 7, 8) 1.4 Visual Studio Code thư viện Graphics: Theo Wikipedia (https://vi.wikipedia.org/wiki/Visual_Studio_Code) Visual Studio Code là trình biên tập mã phát triển bởi Microsoft dành cho Windows, Linux và macOS Nó dựa trên Electron, tảng sử dụng để triển khai ứng dụng Node.js máy tính cá nhân chạy động bố trí Blink Mặc dù sử dụng tảng Electron[5] nhưng phần mềm khác của Atom, thực dựa trình biên tập của Visual Studio Online Visual Studio Code công bố, mắt phiên thử nghiệm vào ngày 29 tháng năm 2015 Microsoft hội nghị Build 2015 Vào ngày 14 tháng năm 2016 Visual Studio Code hoàn tất thử nghiệm được phát hành thức Visual Studio Code trình biên tập mã Nó hỗ trợ nhiều ngôn ngữ chức tùy vào ngôn ngữ sử dụng theo bảng sau Nhiều chức Visual Studio Code không hiển thị menu tùy chọn hay giao diện người dùng Thay vào đó, chúng gọi thơng qua khung nhập lệnh hoặc qua tập tin .json (ví dụ tập tin tùy chỉnh người dùng) Khung nhập lệnh giao diện theo dòng lệnh Tuy nhiên, biến người dùng nhấp nơi khác, nhấn tổ hợp phím để tương tác với bên ngồi Tương tự với dịng lệnh tốn nhiều thời gian để xử lý Khi thực điều q trình xử lý dịng lệnh bị hủy Thư viện Graphics.h (Borland Graphics Interface – biết đến với tên gọi BGI) thư viện đồ họa phổ biến DOS máy tính chạy hệ điều hành Windows thời kì đầu Windows 95, Windows 98 Thư viện cung cấp cho người dùng file: graphics.h và graphics.lib để sử dụng với ngôn ngữ C/C++ module graph nếu người dùng sử dụng ngôn ngữ Pascal Bộ thư viện kèm với IDE Borland C++ 3.1 (1992) Nó chứa số hàm vẽ ảnh cách tạo ảnh chuyển động, in chữ Một điểm mạnh thư viện việc khởi tạo sử dụng đơn giản, đời lâu có nhiều trường đại học sử dụng cho mục đích giảng dạy Thư viện winbmin Đồ họa C sử dụng hàm WinBGIm (Windows 7) sử dụng để vẽ hình dạng khác nhau, hiển thị văn phông chữ khác nhau, thay đổi màu sắc nhiều Thư viện winbgim cho phép bạn sử dụng thói quen đồ họa BGI hỗ trợ chuột đơn giản cho ứng dụng Windows mà bạn viết trình biên dịch mingw32 gnu C ++ CS1300 với trình biên dịch Borland C ++ (phiên 5.0) Nó hoạt động với trình biên dịch Windows khác PHƯƠNG PHÁP NGHIÊN CỨU 2.1 Cài đặt Visual Studio Code thư viện graphics.h: Để cài đặt Visual Studio Code 2019 máy, vào đường dẫn: (https://visualstudio.microsoft.com/download) Tiến hành tải cài đặt theo hướng dẫn đường dẫn: (https://duythanhcse.wordpress.com/2019/04/03/huong-dan-tai-cai-dat-va-su-dungvisual-studio-2019) Cài đặt Graphics theo đường link: (https://github.com/thinhdoanvu/ComputerGraphics/tree/master/Coding/library) Không cách cài Graphics cho DevC, để sử dụng thư viện Graphics Visual Studio Code bạn cần cài đặt thêm TDM-GCC theo đường dẫn: (https://jmeubank.github.io/tdm-gcc), thiết lập Visual Studio Code theo hướng dẫn tại: (https://www.youtube.com/watch?v=J0_vt-7Ok6U) Bạn thay Visual Studio Code phần mềm DevC thực cài đặt thư viện đồ họa theo bước: Bước 1: Copy tập tin 6-ConsoleAppGraphics, ConsoleApp_cpp_graph đến đường dẫn C:\Program Files\Dev-Cpp\Templates Bước 2: Copy tập tin graphics, winbgim đến thư mục C:\Program Files\DevCpp\MinGW64\x86_64-w64-mingw32\include Bước 3: Copy tập tin libbgi.a đến đường dẫn C:\Program Files\Dev-Cpp\ MinGW64\x86_64-w64-mingw32\lib Bước 4: Hiệu chỉnh phiên TDM-GCC cho phù hợp với hệ điều hành phần mềm DevC/C++ theo đường dẫn sau: Tools - Compiler Option ta chọn TDMGCC 4.9.2 32bit Release Thiết lập phiên TDM-GCC phù hợp với DevC/C++ phiên 32 bit 2.2 Sử dụng thuật toán quay lui giải toán: 2.2.1 Tạo biến chuẩn bị cho cài đặt thuật toán: Trước sử dụng giải thuật để giải toán Sử dụng biến mảng có kiểu liệu Boolean để lưu trạng thái hàng đường chéo Từ sử dụng liệu để biết hàng, đường chéo có quân hậu hay chưa Đầu tiên, số dòng, cột đánh số từ xuống dưới, từ trái sang phải theo cách đánh số ma trận Thì ta thấy tính chất:  phần tử nằm hàng có số hàng  phần tử nằm cột có số cột  phần tử nằm đường chéo song song với đường chéo có hiệu số hàng với số cột  phần tử nằm đường chéo song song với đường chéo phụ có tổng số hàng với số cột Quy ước đường chéo song song với đường chéo đường chéo trừ, đường chéo song song với đường chéo phụ đường chéo cộng, khai báo mảng ghi trạng thái sau: Quy ước giá trị False phần tử thứ n biểu thị trạng thái chưa có quân hậu hàng đường chéo thứ n Ví dụ: phần tử hang[8] có giá trị False biểu thị hàng thứ chưa có cờ đặt quân hậu Tiếp tục tạo biến mảng để lưu kết quả: Cuối ta khởi tạo giá trị toàn biến mảng False hàm main(), biểu trị bàn cờ trống: 10 2.2.2 Cài đặt thuật toán quay lui đệ quy: Tạo hàm quay lui tên giai() với tham số truyền vào số thứ tự cột: Với tham số này, thuật toán xét cột không cần biến mảng để ghi trạng thái cột Bắt đầu cài đặt thuật tốn, tạo vịng lập for với biến đếm j = biểu thị cho hàng xét, biểu thức điều kiện j bé số hàng bàn cờ: Trong vòng lập for tạo câu lệnh điều kiện để xét vị trí cờ có nằm hàng, đường chéo cộng, đường chéo trừ đặt quân hậu hay chưa Trường hợp thỏa điều kiện (có quân cờ hàng đường chéo): Lưu kết gán giá trị True để biểu thị hàng, đường chéo cộng, đường chéo trừ xét đặt quân hậu Sau tơ màu vàng cờ hàm floodfill() nhằm biểu thị ô cờ đặt quân hậu dung hàm delay để thể trình giải thuật toán: Tiếp tục sử dụng câu lệnh điều kiện cột xét cột cuối bàn cờ tơ xanh cờ tơ vàng (tô dựa theo giá trị gán mảng ketqua khai báo) Dùng hàm getch() để giữ hình hiển thị kết cho người dùng Tơ vàng ô theo cách tô xanh kết để tiếp tục xét trường hợp Trong trường hợp 11 không thỏa điều kiện (chưa xét đến cột cuối bàn cờ), đệ quy hàm giai() để tiếp tục xét cột kết tiếp: Kế đến gán giá trị phần tử mảng hàng, đường chéo cộng, đường chéo trừ chứa ô xét thành False: tô đen ô cờ để thể bỏ chọn ô cờ xét: Trường hợp khơng thỏa điều kiện (khơng có qn hậu hàng đường chéo): Tô màu đỏ, sau delay khoảng thời gian định, tô đen ô cờ, điều hiển thị hình thể ô cờ xét không thỏa mãn yêu cầu tốn đặt ra: 12 2.2.3 Tồn thuật toán quay lui: 2.3 Các hàm khác chương trình: 2.3.1 Hàm vebanco (vẽ bàn cờ): Hàm vẽ bàn cờ sử dụng hàm có sẵn thư viện graphics.h để vẽ bàn cờ Bàn cờ vẽ hình đồ họa có độ lớn 400×400 pixel, có đỉnh có tọa độ (10;10) (410;410) Các cờ có độ lớn 50×50 pixel, tất thể đường thẳng trắng Hàm gọi hàm main() trước gọi hàm giai() 13 2.3.2 Hàm menu ktramenu: Hàm menu thể tùy chọn tốc độ thoát ứng dụng cho người dùng thông qua nhấp chuột Hàm menu vẽ tùy chọn thành ô với chữ ô để người dùng chọn Trong có chữ nhật ứng với ô từ xuống tăng tốc độ lên lần, giảm tốc độ xuống lần Mỗi có độ lớn 150 ×100 pixel Các có cặp đỉnh: (450;100) (600;150), (450;150) (600;200), (450;350) (600;400) Hàm gọi hàm main() trước sau vẽ bàn cờ Trong đó, hàm ktramenu() kiểm tra xem người dùng có click chuột lúc sử dụng chương trình khơng Hàm gọi vòng lặp for hàm 14 giai() (mỗi xét ô bàn cờ đồng thời xét xem có thao tác click chuột hay khơng) Khai báo biến để lưu tọa độ nhấp chuột mx my sau dùng hàm getmouseclick() để gán hoành độ x click chuột cho mx tung độ y click chuột cho my Nếu có, tùy theo vị trí tọa độ nhấp chuột hình đồ họa nằm ô tùy chọn menu mà có lệnh khác tăng tốc, giảm tốc Ngược lại người dùng khơng click chuột click chuột vào tọa độ không nằm tùy chọn menu, câu lệnh bỏ qua Với tùy chọn × toc / toc Ta khai báo biến tocdo với giá trị 400 truyền vào hàm delay() hàm giai() để thể trình giải cho mắt thường theo dõi Nếu người dùng chọn × toc ta gán tocdo = tocdo/2, / tocdo ta gán tocdo = tocdo×2 Đồng thời phải đặt điều kiện cho giá trị tốc độ trước gán giá trị để tránh trường hợp biến tocdo bị chia lấy nguyên giá trị thời gian delay() lớn (ở đặt tocdo phải 10 4000 tương đương 0.01 giây giây) 2.4 Hàm floodfill cách xác định vị trí quân cờ bàn cờ: Hàm floodfill() hàm có sẵn thư viện graphics.h, cho phép tô màu pixel xung quanh tọa độ định có giá trị màu chênh lệch khoảng giá trị cho phép với pixel tọa độ Sử dụng hàm floodfill() ta tô ô cờ theo quy ước ô cờ xét thỏa điều kiện màu vàng, ô cờ xét không thỏa điều kiện màu đỏ, ô cờ xét tạo thành lời giải màu xanh Tuy nhiên, để tô màu ô cờ ta phải xác định tọa độ để truyền vào hàm tham số Với bàn cờ tạo từ đỉnh đối (10;10) (410;410), độ lớn 400 ×400 pixel, cờ lớn 50 ×50 pixel, ta dùng số hàng cột có sẵn để tạo thành cơng thức tính tọa độ tô màu ô cờ thuộc cột i hàng j: x = (i-1) × 50 + a y = (j-1) × 50 + b Với a,b ∈ (0;50) 15 Ví dụ sử dụng hàm floodfill() việc tô ô cờ: 2.5 Hàm main: Vì chương trình sử dụng thư viện đồ họa, cần sử dụng hàm để khởi động chế độ đồ họa Chương trình khơng gặp lỗi chạy bình thường, ngược lại thơng báo lỗi khởi động đồ họa với mã lỗi nguyên nhân Gán giá trị cho mảng trình bày gọi hàm tạo sau gọi hàm giai() để giải tốn 16 KẾT QUẢ Sau chạy chương trình, kết thu lời giải sau cho toán quân hậu: 17 18 19 Số lượng lời giải thu 92, với thống kê số lượng lời giải tốn qn hậu có từ trang bách khoa toàn thư điện tử Wikipedia Các lời giải không trùng thỏa mãn yêu cầu tốn 20 Q trình mơ tả giải tốn mơ tả trực quan, khiến q trình giải toán quân hậu thuật toán quay lui đệ quy dễ dàng theo dõi trước Minh họa mơ tả q trình giải toán quay lui đệ quy Minh họa lời giải hiển thị thư viện đồ họa Các ô cờ đặt quân hậu xét, đúng, sai minh họa màu vàng, xanh đỏ giúp mô tả toán Các tùy chọn tăng giảm tốc độ giúp người dùng dễ dàng theo dõi với tốc độ mong muốn khơng xảy lỗi Minh họa chương trình xuất lời giải 21 Minh họa chương trình giải tốn 22 KẾT LUẬN Sau hồn thành báo cáo nhận thấy ưu nhược điểm thuật toán quay lui đệ quy với chương trình Visual Studio Code so với thuật tốn chương trình khác: Ưu điểm thuật toán quay lui đệ quy: - Dễ cài đặt thuật toán - Cho kết xác - Có thể áp dụng với tốn xếp hậu (dạng tổng quát toán quân hậu) Nhược điểm thuật toán: - Cần xét đến trường hợp nên thời gian giải chậm - Không thể dùng với toán xếp hậu số quân hậu nhiều thời gian giải lâu Ưu điểm Visual Studio Code: - Môi trường lập trình chun nghiệp - Có nhiều extension (các chương trình hỗ trợ tích hợp) cho phép lập trình dễ dàng Nhược điểm Visual Studio Code: - Khó cài đặt để sử dụng - Việc cài đặt thư viện đồ họa khó khăn so với Dev C chương trình khác - Khơng hỗ trợ sẵn biên dịch chương trình đồ họa 23 TÀI LIỆU THAM KHẢO https://github.com/thinhdoanvu/ComputerGraphics/tree/master/Coding/library https://vi.wikipedia.org/wiki/Visual_Studio_Code https://duythanhcse.wordpress.com/2019/04/03/huong-dan-tai-cai-dat-va-sudung-visual-studio-2019 https://www.youtube.com/watch?v=J0_vt-7Ok6U 24

Ngày đăng: 31/07/2022, 17:12

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w