Assignment 2COMP9021, Trimester 3, 20241 General matters 1.1 Aim The purpose of the assignment is to:
develop your problem solving skills;
- design and implement the solutions to problems in the form of medium sized Python programs;practice the design and implementation of search techniques, with recursion as a good approach;
- design and implement an interface based on the desired behaviour of an application program;
- possibly practice using the re and numpy modules.
1.2 Submission
can be submitted morethan once; the last version is marked. Your assignment is due by November 18, 10:00am.
1.3 Assessment
The assignment is worth 13 marks. It is going to be tested against a number of inputs. For each test, theautomarking script will let your program run for 30 seconds. can be submitted up to 5 days after the deadline. The maximum mark obtainable reducesby 5% per full late day, for up to 5 days. Thus if students A and Bhand in assignments worth 12 and 11,both two days late (that is, more than 24 hours late and no morethan 48 hours late), then the maximummark obtainable is 11.7, so A gets min(11.7, 12) = 11.7 and B gets min(11.7, 11) = 11.The outputs of your programs should be exactly as indicated..4 Reminder on plagiarism policy You are permitted, indeed encouraged, to discuss ways to solve the assignment with other people. Suchdiscussions must be in terms of algorithms, not code. But you mustimplement the solution on yourown. Submissions are routinely scanned for similarities that occur when students copy and modify otherpeople’s work, or work very closely together on a single implementation. Severe penalties apply.12 Solving crosswords
2.1 General description The aim is to fill in a crossword grid, in which some letters might have been placed already, in one of twoays:
- being given the collection of all missing entries in an underlying solution to the crossword, find ay to place those entries in the grid (in one of possibly more than one way);
- being given a collection of words, find a way to select and place some of those words in the grid sothat it solves the puzzle (in one of possibly more than oneway).We will consider grids with at least 2 rows and at least 2 columns, and such that any cell is next toanother cell, though maybe not next to both horizontal andvertical cells; so any cell is part of a word ofat least 2 letters, and by word we mean a word with at least 2 letters.
A presentation of a grid provided as input will be captured in a .tex file, and a presentation of asolved puzzle will also be captured in a .tex file; those .tex files can be given as arguments to pdflatex
to generate .pdf files that display grids in a pleasing graphical form, but play no role in the assignment.The code will be all about the design and implementation of aCrossword class. An object of class
described, and also benefit from theimple代寫COMP9021 Solving crosswords mentation of the __str__() special method to display some information about the grid and thewords it possibly containsalready.partial_grid_3.tex is an example of a .tex file for a grid in which letters have been placed already,that can be considered as an input file, and here is the .pdf file created by pdflatex from this .tex file.solved_partial_grid_3.tex is an example of a .tex file for a solution to that grid, that can beconsidered as an output file, and here is the .pdf file created by pdflatex from this .tex file.The contents of all input .tex files will be of the following form:For input files, what lies between \begin{tikzpicture} and \end{tikzpicture} is of the followingform:\begin{crossgrid}[h=_, v=_]\blackcases{_/_, ..., _/_}\words[v]{_/_/_, ..., _/_/_}\words[h]{_/_/_, ..., _/_/_}\end{crossgrid}Each of\blackcases{_/_, ..., _/_},
words[v]{_/_/_, ..., _/_/_} and\words[h]{_/_/_, ..., _/_/_}2is optional and can appear in any order.In \begin{crossgrid}[h=_, v=_], the first and second occurrences of _ denoteintegers at leastequal to 2, that represent the horizontal dimension and the vertical dimension of the grid, respectively; let h-dim and v-dim denote those dimensions,.In\blackcases{_/_, ..., _/_}, each occurrence of _/_ denotes a slash-separated pair of integers
(i, j) with 1 ≤ i ≤ h-dim and 1 ≤ j ≤ v-dim, to denote that there is a black square at theintersection of the i th column and the j th row. If \blackcases{_/_, ..., _/_} is presentthenthere is at least one such pair, consecutive pairs being separated by a comma.
- \words[v]{_/_/_, ..., _/_/_}, each occurrence of _/_/_ denotes a slash-separated tripl(i, j, w) where i and j are integers with 1 ≤ i ≤ h-dim and 1 ≤ j ≤ v-dim, and where w is aword of at least 2 letters that is vertically placed in the grid and whose first letter is at the intersection of the i th column and the j th row. If \words[v]{_/_/_, ..., _/_/_} is present then there isat least one such triple, consecutive triples being separated by a comma.
- In \words[h]{_/_/_, ..., _/_/_}, each occurrence of _/_/_ denotes a slash-separated triple(i, j, w) where i and j are integers with 1 ≤ i ≤ h-dim and 1 ≤ j ≤ v-dim, and wherew is aword of at least 2 letters that is horizontally placed in the grid and whose first letteris at theintersection of the i th column and the j th row. If \words[h]{_/_/_, ..., _/_/_} is present thenthere is at least one such triple, consecutive triples being separated by a comma.You can assume that the input is valid: no word or black square will start or extend beyond the dimensionsthe grid.For output files, what lies between \begin{tikzpicture} and \end{tikzpicture} is of the form\gridcross{_, ... _} where _, ... _ is a comma-separated sequence of vdimstrings, each of lengthh-dim, to denote from top to bottom each of the rows of the filled grid, using *s to represent black squares,and using uppercase letters forthegrid’s entries.
In .tex files, there can be spaces between tokens almost everywhere (the pas-crosswords packageactually prevents spaces to be used around some of the / characters). Also,.tex files, the leftmostoccurrence of a % marks the beginning of a comment that runs frothis symbol included all the wayto the end of the physical line, including the \n character. This allows one to have many physical linesto represent a unique logical line, and can be used to, for instance, have \blackcases{_/_, ..., _/_},\words[v]{_/_/_, ...,_/_/_}, \words[h]{_/_/_, ..., _/_/_} and \gridcross{_, ... _} splitover more than one physical line and improve readability. It is therefore advisable to process a .tex filein such a that its content is captured as a single string with all space removed, before searching for
atterns of interest in this string.
2.2 Analysing a grid (3 marks)
Your program will allow Crossword objects to be created from .tex files that you can assume are storedin the working directory, and whose contents satisfy all conditions spelled out in Section 2.1. Makinguse of the .tex files empty_grid_1.tex, empty_grid_2.tex, empty_grid_3.tex, partial_grid_1.tex,partial_grid_2.tex and partial_grid_3.tex, having for associated .pdf files empty_grid_1.pdf,empty_grid_2.pdf, empty_grid_3.pdf, partial_grid_1.pdf, partial_grid_2.pdf and partial_grid_3.pdf,here is a possibleinteractionPassing as argument to print() a denotation of a Crossword object results in an output of the kind
A grid of width _ and height _, with _ black case[s], filled with _ letter[s],
with _ complete vertical word[s] and _ complete horizontal word[s].
where
- the first occurrence of _ is a number that represents the horizontal dimension of the grid,3• the second occurrence of _ is a number that represents the vertical dimension of the grid,the third occurrence of _ is no, 1 or a number at least equal to 2 that represents the number n ofblack cases in the grid (of course it is case if n = 1 and cases otherwise),thefourth occurrence of _ is no, 1 or a number at least equal to 2 that represents the number nofletters alredy placed in the grid (of course it is letter if n = 1 and letters otherwise),the fifth occurrence of _ is no, 1 or a number at least equal to 2 that represents the n ofvertical words in the grid (of course it is word if n = 1 and words otherwise), andthe sixth occurrence of _ is no, 1 or a number at least equal to 2 that represents the number n of
horizontal words in the grid (of course it is word if n = 1 and words otherwise).
2.3 Filling in a grid with given words (5 marks)
Crossword objects can call the fill_with_given_words() method, that takes two arguments.
- First, the name of a .txt file, meant to exist in the working directory and store a number of wordsone word per line (without empty line, without space on any line). You can assume that the file
ndeed exists and has the expected contents. The file could be empty, and there could be more thanone occurrence of a given word.
Second, the name of a .tex file, meant to store a representation of a solution in case a solutionexists.The aim is to complete all missing entries precisely with the words stored in the file provided as firstargument; so there should be as many words in the file as there re incomplete words in the grid; wordsdo not have to be distinct in the file, because a given word can appear more than once in a grid.
y, it can't be filled with these words!
Otherwise, the method prints out:I filled it!Result captured in _.where _ is the name of the .tex file that has been provided as argument to the method. The solutionthat has been discovered is stored in that file. If the file does not exist then it is created, in the workingdirectory; if it does exist then it is overwritten. There could be more than one solution; only one solutionis sought after, and any correct solution is acceptable. In any case, the method returns None.Here is a possible interaction.– filled_empty_grid_2.tex,– filled_empty_grid_3.tex and– filled_partial_grid_2.tex.The associated .pdf files are– filled_empty_grid_2.pdf,– filled_empty_grid_3.pdf andfilled_partial_grid_2.pdf.It is advisable to make sure that the spaces in the .tex files produced during the interaction areexactly as shown. Still, whitespace will be ignored for assessment purposes, but of course, all othenonspace characters have to be exactly the same, character for character.42.4 Solving a crossword (5 marks) Crossword objects can call the solve() method, that takes as argument the name of a .tex file, meantto store a representation of a solution in case a solution exists.
The aim is to complete all missing entries with words from the file dictionary.txt. That file isprovided, meant to be stored in the working directory, and you can assume thatthis is the case indeed. Aword in dictionary.txt could be used more than once, because a given word can appear more than oncin a grid. The grid could already contain complete words that are not in dictionary.txt. This is fine.It should not be checked that any complete word in the input grid is in dictionary.txt; this might notbe the case, and that is fine. But any incomplete or missing word has tobe one from dictionary.txt.If the task is impossible, then the method prints out:Hey, it can't be solved!
Otherwise, the method prints out:I solved it!Result captured in _.where _ is the name of the .tex file that has been provided as argument to the method. The solutionthat has been discovered is stored in that file. If the file does not exist then it is created, in the working; if it does exist then it is overwritten. There could be more than one solution; only one solutionis sought after, and any correct solution is acceptable. In any case, the method returns NoneHere is a possible interactionThe .tex files that have been created or overwritten during this interaction aresolved_empty_grid_1.tex,– solved_empty_grid_2.tex,– solved_partial_grid_1.tex an– solved_partial_grid_3.tex.The associated .pdf files are– solved_empty_grid_1.pdf,– solved_empty_grid_2.pdf,– solved_partial_grid_1.pdf and– solved_partial_grid_3.pdf.It is advisable to make sure that the spaces in the .tex files produced during the interaction are
exactly as shown. Still, whitespace will be ignored for assessment purposes, but of course, all othernonspace characters have to be exactly the same, character for character