代写COMP3411/9814 Artificial Intelligence Term 1, 2024 Assignment 1 – Bridge Puzzle代做C/C++编程
- 首页 >> CSCOMP3411/9814 Artificial Intelligence Term 1, 2024
Assignment 1 – Bridge Puzzle
Due: Friday 15 March, 10pm
Marks: 12% of final assessment
Specification
This project is based on a popular puzzle, variously known as "Hashiwokakero", "Hashi" or "Bridges". You will need to write a program to solve this puzzle, and provide a brief description of the algorithm and data structures you have used. The input to your program will be a rectangular array of numbers and dots, for example:
Each number represents an "island", while the dots represent the empty space (water) between the islands. Numbers larger than 9 are indicated by 'a' (10), 'b' (11) or 'c' (12). The aim is to connect all the islands with a network of bridges, satisfying these rules:
.1...6...7....4.4.2.
..4.2..2...3.8...6.2 .....2.............. 5.c.7..a.a..5.6..8.5 .............2...... ...5...9.a..8.b.8.4. 4.5................3 ....2..4..1.5...2... .2.7.4...7.2..5...3. ............4..3.1.21. all bridges must run horizontally or vertically
2. bridges are not allowed to cross each other, or other islands
3. there can be no more than three bridges connecting any pair of islands
4. the total number of bridges connected to each island must be equal to the number on the island
For example, after reading the 10-line input above, your program might produce this output: Note that single bridges are indicated by the characters '-' or '|', pairs of bridges by '=' or '"' and triples by 'E' or '#', depending on whether they run horizontally or vertically. Water between bridges and islands is indicated by space characters ' '.
In some cases, there may be many solutions, in which case your program should only print one solution. More details about the puzzle can be found on this Wikipedia page. Note, however, that our version allows up to 3 bridges instead of 2; also, we do not insist that the entire graph be connected.
1---6EEE7====4=4=2
4-2" 2 " 3E8EEE6 2
# |2 " " " # "
5EcE7EEaEa==5"6EE8=5
" # " # #2# |
" #5===9Ea--8=bE8E4|
4=5# " # " # " |3
#2==4 #1-5 # 2 |"
2=7=4===7=2" 5===3"
4==3-1 2
Tools
An executable file called is provided in the tools directory which can be used to generate sample data of any specified size (type for details). Another executable called is also provided, to help you test the validity of your solutions (see FAQ for details). bridgen bridgen -help bridgecheck
Questions
At the top of your code, in a block of comments, you must provide a brief answer (one or two paragraphs) to this Question:
Briefly describe how your program works, including any algorithms and data structures employed, and explain any design decisions you made along the way.
Language Options
You are free to write the code in a language of your choosing.
If you write in C, C++, or another compiled languge, your program will be invoked by:
You should submit your source files (no object files) as well as a which, when invoked with the command , will produce an executable called
./hashi Makefile make hashi