Place your order

Fill in the order form and provide all details of your assignment.

Proceed with the payment

Choose the payment system that suits you most.

Receive the final file

Once your paper is ready, we will email it to you

Consider the famous map coloring problem. Your goal is to find the minimum numbe


Consider the famous map coloring problem. Your goal is to find the minimum number of colors and the color name for the entire map such that two adjacent regions of the map are not colored with the same color. For example, in Fig 1, we need a minimum of 3 colors (red, green, blue). For this programming assignment, you need to write a program in Java or Python using the Constraint Satisfaction Problem (CSP) algorithm. Here are the detailed requirements. Your program must be complete, compile able, and produce output. Your program must be generic enough to solve problems with other country maps. Your program should be able to handle a minimum of 2 and a maximum of 20 vertices/districts. 2 =< V >= 20, where V is total number of vertices. The total number of colors you can use is 7. Red, Green, Blue, Yellow, Violet, Gray, Orange. Remember, your goal is to choose the minimum number of colors. For example, given in Fig 1, you only need 3 colors to satisfy the goal (no adjacent regions has the same color) Your program will read the graph from a text file (example: graph.txt) Follow the order of the color mentioned in number 4. For example, if you need 4th color, pick Yellow, if you need 5th color, then pick Violet and so on. This would be easier for you when you are assessing your peer’s assignment by comparing with your output. You must follow the CSP backtracking algorithm. If your program can’t solve the problem using 7 colors, it should output “Not Possible with 7 colors.” Sample Input (graph.txt) (Based on Fig 1) 5 A B C D B A C C A B D D A C E Input file Explanation: The first line represents the total number of vertices/nodes/districts. In this case, the total number is 5. After that, there will be the same number of lines representing the vertex name and their adjacent vertices. Each vertex and it’s adjacent must be separated by space. For example, A B C D means vertex A has 3 adjacent vertices which are B, C, and D. The last line represents the vertex E with no adjacent. Sample Output (Based on Fig 1) A red B green C blue D green E red Output Explanation: Your output should mention each vertex name in a separate line and the appropriate color name separated by one space. If a given map is not possible to color with the given 7 colors, simple output the following line: Not possible with 7 colors Sample coding on how to read the input file (graph.txt) // assuming graph.txt file located in the same project folder // if not then add the entire path File file = new File(“graph.txt”); BufferedReader br = new BufferedReader(new FileReader(file)); int total_no_vertices = Integer.parseInt(br.readLine()); for (int i = 1; i <= total_no_vertices; ++i) { String line = br.readLine(); String[] vertex_and_adjacent = line.split(" "); for (int j = 0; j < vertex_and_adjacent.length; ++j) { // Assign the vertex vertex_and_adjacent[0] into your data structure // Assign it's adjacent vertices from vertex_and_adjacent[1] to vertex_and_adjacent[length - 1] into another data structure } } You will be graded on the following: Does the program compile? Does the program correctly read the input file? Does the data structure correctly represent the map/graph? Is the Constraint Satisfaction Problem (CSP) backtracking algorithm correctly implemented? Does the program produce the correct output? Do you think given a scenario where 7 colors are not enough to solve the problem, the program will give the corresponding output?