- Besides baseball, McDonald’s, and reality TV, few things are as canonically American as hopping in the
car for an old-fashioned road trip. We’ve prepared a dataset of major highway segments of the United
States (and parts of southern Canada and northern Mexico), including highway names, distances, and
speed limits; you can visualize this as a graph with nodes as towns and highway segments as edges.
We’ve also prepared a dataset of cities and towns with corresponding latitude-longitude positions.
These files should be in the GitHub repo you cloned in step 0. Your job is to implement algorithms
that find good driving directions between pairs of cities given by the user. Your program should be
run on the command line like this:
./route.py [start-city] [end-city] [routing-algorithm] [cost-function]
where:
- start-cityandend-cityare the cities we need a route between.
- routing-algorithmis one of:
- bfsuses breadth-first search (which ignores edge weights in the state graph)
- uniformis uniform cost search (the variant of bfs that takes edge weights into consideration)
- dfsuses depth-first search
- astar uses A* search, with a suitable heuristic function
- cost-functionis one of:
- distancetries to find a route with the shortest total distance
- timetries to find the fastest route, for a car that always travels at the speed limit
- segmentstries to find a route with the fewest number of “turns” (i.e. edges of the graph)
The output of your program should be a nicely-formatted, human-readable list of directions, including
travel times, distances, intermediate cities, and highway names, similar to what Google Maps or another
site might produce. In addition, thelastline of output should have the following machine-readable
output about the route your code found:
[total-distance-in-miles] [total-time-in-hours] [start-city] [city-1] [city-2] ... [end-city]
Please be careful to follow these interface requirements so that we can test your code properly. For
instance, the last line of output might be:
51 1.0795 Bloomington,_Indiana Martinsville,_Indiana Jct_I-465_&_IN_37_S,_Indiana Indianapolis,_Indiana
Like any real-world dataset, our road network has mistakes and inconsistencies; in the example above,
for example, the third city visited is a highway intersection instead of the name of a town. Some of
these “towns” will not have latitude-longitude coordinates in the cities dataset; you should design your
code to still work well in the face of these problems.
In the comment section at the top of your code file, please include a brief analysis of the results of your
program, answering the questions: (1) Which search algorithm seems to work best for each routing
options? (2) Which algorithm is fastest in terms of the amount of computation time required by your
program, and by how much, according to your experiments? (3) Which algorithm requires the least
memory, and by how much, according to your experiments? (4) Which heuristic function(s) did you
use, how good is it, and how might you make it/them better?
Extra credit.For some extra credit, implement two additional cost-functions:longtourshould try to
find the longest distance driving path between the two cities that does not visit the same city twice,
andstatetourshould try to find a route with the shortest total distance that includes passing through
at least one city in each of the 48 contiguous U.S. states.
- The course staff of a certain Computer Science course randomly assigns students to teams for their first assignment of the semester to help force people to get used to the real-world situation of working on diverse groups of teams of programmers. But since they are not completely heartless, the instructors allow students to give preferences on their teams for future assignments. In particular, each student is sent an electronic survey and asked to give answers to four questions:
(a) What is your user ID?
(b) Would you prefer to work alone, in a team of two, in a team of three, or do you not have a
preference? Please enter 1, 2, 3, or 0, respectively.
(c) Which student(s) would you prefer to work with? Please list their user IDs separated by commas,
or leave this box empty if you have no preference.
(d) Which students would you prefer not to work with? Please list their IDs, separated by commas.
You can assume every student fills out the survey exactly once. Ideally, student preferences would be
compatible with each other so that the group assignments would make everyone happy, but inevitably
this is not possible because of conflicting preferences. So instead, being selfish, the course staff would
like to choose the group assignments that minimize the total amount of work they’ll have to do. They
estimate that:
- They needkminutes to grade each assignment, so total grading time isktimes number of teams.
- Each student who requested a specific group size and was assigned to a different group size will complain to the instructor after class, taking 1 minute of the instructor’s time.
- Each student who is not assigned to someone they requested will send a complaint email, which will takenminutes for the instructor to read and respond. If a student requested to work with multiple people, then they will send a separate email for each person they were not assigned to.
- Each student who is assigned to someone they requestednotto work with (in question 4 above) will request a meeting with the instructor to complain, and each meeting will lastmminutes. If a student requested not to work with two specific students and is assigned to a group with both of them, then they will request 2 meetings.
The total time spent by the course staff is equal to the sum of these components. Your goal is to write
a program to find an assignment of students to teams that minimizes the total amount of work the
course staff needs to do, subject to the constraint that no team may have more than 3 students. Your
program should take as input a text file that contains each student’s response to these questions on a
single line, separated by spaces. For example, a sample file might look like:
djcran 3 zehzhang,chen464 kapadia
chen464 1 _ _
fan6 0 chen464 djcran
zehzhang 1 _ kapadia
kapadia 3 zehzhang,fan6 djcran
steflee 0 _ _
where the underscore character () indicates an empty value. Your program should be run like this:
./assign.py [input-file] [k] [m] [n]
wherek,m, andnare values for the parameters mentioned above, and the output of your program
should be a list of group assignments, one group per line, with user names separated by spaces followed
by the total time requirement for the instructors, e.g.:
djcran chen
kapadia zehzhang fan
steflee
534
which proposes three groups, with two people, three people, and one person, respectively.
- Consider a variant of the 15-puzzle, but with the following important change. Instead of sliding a single tile from one cell into an empty cell, in this variant, either one, two, or three tiles may be slid left, right, up or down in a single move. For example, for a puzzle in this configuration:
the valid successors are:
1 2 3 4 1 2 3 4 1 2 3 4
5 6 7 8 5 6 7 8 5 6 7 8
9 10 12 9 10 12 9 10 12
13 14 15 11 13 14 15 11 13 14 15 11
1 2 4 1 2 3 4 1 2 3 4
5 6 3 8 5 6 8 5 6 7 8
9 10 7 12 9 10 7 12 9 10 15 12
13 14 15 11 13 14 15 11 13 14 11
The goal is to find a short sequence of moves that restores the canonical configuration (on the left
above) given an initial board configuration. Write a program called solver16.py that finds a solution
to this problem efficiently using A* search. Your program should run on the command line like:
./solver16.py [input-board-filename]
whereinput-board-filenameis a text file containing a board configuration in a format like:
1 2 3 4
5 6 7 8
9 0 10 12
13 14 15 11
where 0 indicates the empty position. The program can output whatever you’d like, except that the
last line of output should be a representation of the solution path you found, in this format:
[move-1] [move-2] ... [move-n]
where each move is encoded as a letterL,R,U, orDfor left, right, up, or down, respectively, followed
by 1, 2, or 3 indicating the number of tiles to move, followed by a row or column number (indexed
beginning at 1). For instance, the six successors shown above would correspond to the following six
moves (with respect to the initial board state):
R13 R23 L13 D23 D13 U