代写CSE 101 Introduction to Data Structures and Algorithms Programming Assignment 2调试Haskell程序

CSE 101

Introduction to Data Structures and Algorithms

Programming Assignment 2

Breadth First Search and Shortest Paths

The purpose of this assignment is to implement a Graph ADT and some associated algorithms in C.  This project will utilize your List ADT from pa1.  Begin by reading the handout on Graph Algorithms, as well as appendices B.4, B.5 and sections 22.1, 22.2 from the text.

The adjacency list representation of a graph consists of an array of Lists.  Each List corresponds to a vertex in the graph and gives the neighbors of that vertex.  For example, the graph

has adjacency list representation

1: 2 3

2: 1 4 5 6

3: 1 4

4: 2 3 5

5: 2 4 6

6: 2 5

You will create a Graph ADT that uses this method of representing a graph.  Each vertex will be identified with an integer label in the range 1 ton, where n is the number of vertices in the graph.  The client program in this project will be called FindPath.c, and will use the Graph ADT to find shortest paths (i.e. paths with fewest edges) between pairs of vertices.  It will take two command line arguments, as follows.

$ FindPath input_file output_file

File Formats

The input file will be in two parts.  The first part will begin with a line consisting of a single integer n giving the number of vertices in the graph. Each subsequent line will represent an edge by a pair of distinct numbers in the range 1 ton, separated by a space.  These numbers are the end vertices of the corresponding edge.  The first part of the input file defines the graph, and will be terminated by a dummy line containing “ 0 0” .  After these lines are read your program will print the adjacency list representation of the graph to the output file. For instance, the lines below define the graph pictured above, and cause the above adjacency list representation to be printed.

6

1 2

1 3

2 4

2 5

2 6

3 4

4 5

5 6

0 0

The second part of the input file will consist of a number of lines, each consisting of a pair of integers in the range 1 to n, separated by a space.  Each line specifies a pair of vertices in the graph; a starting point (source) and an ending point (destination).  The second part of the input will also be terminated by the dummy line “ 0 0” .  For each source-destination pair your program will do the following:

•   Perform. a Breadth First Search (BFS) from the given source vertex.  This assigns a parent vertex (also called a predecessor, which may be nil) to every vertex in the graph.   The BFS  algorithm will be discussed in class and is described in general terms below.  The pseudo-code for BFS can be found in section 22.2 of the text, and is also presented at Examples/Pseudo-Code/GraphAlgorithms on the class webpage.

•   Use the results of BFS to print out the distance from the source vertex to the destination vertex, then use the predecessors to recursively printout a shortest path from source to destination. See the algorithm Print-Path in section 22.2 of the text, and also at Examples/Pseudo-Code/GraphAlgorithms.

Examples

Input File: Output File:

6                           1: 2 3

1 2                         2: 1 4 5 6

1 3                         3: 1 4

2 4                            4: 2 3 5

2 5                            5: 2 4 6

2 6                         6: 2 5

3 4

4 5                         The distance from 1 to 5 is 2

5 6                         A shortest 1-5 path is: 1 2 5

0 0

1 5                         The distance from 3 to 6 is 3

3 6                         A shortest 3-6 path is: 3 1 2 6

2 3

4 4                         The distance from 2 to 3 is 2

0 0                          A shortest 2-3 path is: 2 1 3

The distance from 4 to 4 is 0 A shortest 4-4 path is: 4

If there is no path from source to destination (which may happen if the graph is disconnected), then your program will print a message to that effect.  Note that there may be more than one shortest path joining a given pair of vertices. The particular path discovered by BFS depends on the order in which it steps through the vertices in each adjacency list.   We  adopt  the  convention  in this project that vertices are always processed in sorted order, i.e. by increasing vertex labels.  The output of BFS is uniquely determined by this requirement.  Therefore your Graph ADT should maintain the adjacency lists in sorted order.   The following example represents a disconnected graph.

Input File: Output File:

7                              1: 4 5

1 4                        2: 3 6

1 5                        3: 2 7

4 5                        4: 1 5

2 3                        5: 1 4

2 6                            6: 2 7

3 7                        7: 3 6

6 7

0 0                          The distance from 2 to 7 is 2

2 7                        A shortest 2-7 path is: 2 3 7

3 6

1 7                          The distance from 3 to 6 is 2

0 0                          A shortest 3-6 path is: 3 2 6

The distance from 1 to 7 is infinity No 1-7 path exists

Your program’s operation can be broken down into two basic steps, corresponding to the two groups of input data.

1.   Read and store the graph and print out its adjacency list representation.

2.   Enter a loop that processes the second part of the input.  Each iteration of the loop should read in one pair of vertices (source, destination), run BFS on the source vertex, print the distance to the destination vertex, then find and print the resulting shortest path, if it exists, or print a message that no path from source to destination exists (as in the above example).

What is Breadth First Search? Given a graph G and a vertex s, called the source vertex, BFS systematically explores the edges of G to discover every vertex that is reachable from s.  It computes the distance from s to all such reachable vertices.   It also produces a BFS tree with root s that contains all vertices reachable from s.  For any vertex v reachable from s, the unique path in the BFS tree from s to v is a shortest path in G from s to v.    Breadth First Search is so named because it expands the frontier between discovered and undiscovered vertices uniformly across the breadth of the frontier; i.e. the algorithm discovers all vertices at distance k from s before discovering any vertices at distance k+1.   To keep track of its progress and to construct the tree, BFS requires that each vertex v in G possess the following attributes: a color color[v] which may be white, gray, or black; a distance d[v] which is the distance from source s to vertex v; and a parent (or predecessor) p[v] that refers to the parent of v in the BFS tree.  At any point during the execution of BFS, the white vertices are those that are as yet undiscovered, black vertices are finished, and the gray vertices are discovered, but not all of their neighbors have been discovered.  The gray vertices thus form the frontier between undiscovered and finished vertices.  BFS uses a FIFO queue to manage the set of gray vertices.   Use  your  List  ADT  from  pa2 to implement both this FIFO queue,  and the adjacency lists representing the graph itself.

Your Graph ADT will be implemented in files Graph.c and Graph.h.   Graph.c defines a struct called GraphObj, and Graph.h will define a type called Graph that is a pointer to this struct.  (It would be a good idea at this point tore-read the handout ADTs and Modules in C.)  Without going any further into the details of BFS, we can see a need for the following fields in your struct GraphObj:

•   An array of Lists whose ith  element contains the neighbors of vertex i.

•   An array of ints (or chars, or strings) whose ith  element is the color (white, gray, black) of vertex i.

•   An array of ints whose ith  element is the parent of vertex i.

•   An array of ints whose ith  element is the distance from the (mostrecent) source to vertex i.

You should also include fields storing the number of vertices (called the order ofthe graph), the number of edges (called the size of the graph), and the label of the vertex that was most recently used as source for BFS.  It is recommended that all arrays be of length n + 1, where n is the number of vertices in the graph, and that only indices 1 through n be used. This is so that array indices can be directly identified with vertex labels.

Your Graph ADT is required to export the following operations through the file Graph.h:

/*** Constructors-Destructors ***/ Graph newGraph(int n);

void freeGraph(Graph* pG);

/*** Access functions ***/ int getOrder(Graph G);

int getSize(Graph G);

int getSource(Graph G);

int getParent(Graph G, int u); int getDist(Graph G, int u);

void getPath(List L, Graph G, int u);

/*** Manipulation procedures ***/ void makeNull(Graph G);

void addEdge(Graph G, int u, int v); void addArc(Graph G, int u, int v);  void BFS(Graph G, int s);

/*** Other operations ***/

void printGraph(FILE* out, Graph G);

In addition to the above prototypes Graph.h will define the type Graph as well as   #define constant macros INF and NIL that represent infinity and an undefined vertex label, respectively.  For the purpose of implementing BFS, any negative int value is an adequate choice for INF, and any non-positive int can stand in for NIL, since all valid vertex labels will be positive integers.   INF and NIL should of course be different integers.

Function newGraph()returns a Graph pointing to a newly created GraphObj representing a graph having n vertices and no edges.  Function freeGraph() frees all heap memory associated with the Graph *pG, then sets the handle *pG to NULL.  Functions getOrder() and getSize() return the corresponding field values, and getSource() returns the source vertex most recently used in function BFS(), or NIL if BFS() has not yet been called.  Function getParent() will return the parent of vertex u in the BFS tree created by BFS(), or NIL if BFS()has not yet been called. Function getDist()returns the distance from the most recent BFS source to vertex u, or INF if BFS () has not yet been called.  Function getPath() appends to the List L the vertices of a shortest pathin G from source to u, or appendsto L the value NIL if no such path exists.  getPath() has the precondition getSource(G)!=NIL, so BFS() must be called before  getPath() is  called.  Functions  getParent(),   getDist() and  getPath() all  have  the precondition  1 ≤ u ≤ getOrder(G).   Function  makeNull() deletes all edges of G, restoring it to its original (no edge) state.   (This is called a null graph in graph theory literature).   Function addEdge() inserts a new edge joining u to v, i.e. u is added to the adjacency List of v, and v to the adjacency List of u. Your program is required to maintain these lists in sorted order by increasing labels.  Function addArc() inserts a new directed edge from u to v, i.e. v is added to the adjacency List of u (but not uto the adjacency List of v).  Both addEdge() and addArc() have the precondition that their two int arguments must lie in the range 1 to getOrder(G).  Function BFS() runs the BFS algorithm on the Graph G with source s, setting the color, distance, parent, and source fields of G accordingly.  It also has the precondition that the int argument  s lies in the range  1  to  getOrder(G).    Finally,  function  printGraph() prints the adjacency list representation of G to the file pointed to by out.   The format of this representation should match the above examples, so all that is required by the client is a single call to printGraph().

As in all ADT modules written in C, you must include a test client called GraphTest.c that tests your Graph operations in isolation.   Observe that since the Graph ADT includes an operation having a List argument (namely getPath()), any client of Graph is also a client of List. For this reason the file Graph.h should #include the header List.h.  (See the handout C Header File Guidelines for generally accepted policies on using  .h files.)  As in pa1, you will write a Makefile that creates the executable binary called FindPath.  Include a clean utility in your Makefile that removes all executable binaries and intermediate  .o files.  A Makefile is included on the website that you may change as you see fit.

Thus, you will submit eight files in all:

List.c          written by you

List.h          written by you

Graph.c         written by you

Graph.h         written by you

GraphTest.c     written by you

FindPath.c      written by you

Makefile        provided, alter as you see fit

README.md       a list of files submitted, and any notes to the grader

You will also find a file called GraphClient.c in /Examples/pa2 that computes a few graph theoretic quantities using BFS. Do not turn in this file, but use it in your own tests if you like. It should be considered to be a weak test of our Graph ADT and does not take the place of your own GraphTest.c.

Please start this project early and get help from myself, Course Tutors and TAs as needed.





热门主题

课程名

mktg2509 csci 2600 38170 lng302 csse3010 phas3226 77938 arch1162 engn4536/engn6536 acx5903 comp151101 phl245 cse12 comp9312 stat3016/6016 phas0038 comp2140 6qqmb312 xjco3011 rest0005 ematm0051 5qqmn219 lubs5062m eee8155 cege0100 eap033 artd1109 mat246 etc3430 ecmm462 mis102 inft6800 ddes9903 comp6521 comp9517 comp3331/9331 comp4337 comp6008 comp9414 bu.231.790.81 man00150m csb352h math1041 eengm4100 isys1002 08 6057cem mktg3504 mthm036 mtrx1701 mth3241 eeee3086 cmp-7038b cmp-7000a ints4010 econ2151 infs5710 fins5516 fin3309 fins5510 gsoe9340 math2007 math2036 soee5010 mark3088 infs3605 elec9714 comp2271 ma214 comp2211 infs3604 600426 sit254 acct3091 bbt405 msin0116 com107/com113 mark5826 sit120 comp9021 eco2101 eeen40700 cs253 ece3114 ecmm447 chns3000 math377 itd102 comp9444 comp(2041|9044) econ0060 econ7230 mgt001371 ecs-323 cs6250 mgdi60012 mdia2012 comm221001 comm5000 ma1008 engl642 econ241 com333 math367 mis201 nbs-7041x meek16104 econ2003 comm1190 mbas902 comp-1027 dpst1091 comp7315 eppd1033 m06 ee3025 msci231 bb113/bbs1063 fc709 comp3425 comp9417 econ42915 cb9101 math1102e chme0017 fc307 mkt60104 5522usst litr1-uc6201.200 ee1102 cosc2803 math39512 omp9727 int2067/int5051 bsb151 mgt253 fc021 babs2202 mis2002s phya21 18-213 cege0012 mdia1002 math38032 mech5125 07 cisc102 mgx3110 cs240 11175 fin3020s eco3420 ictten622 comp9727 cpt111 de114102d mgm320h5s bafi1019 math21112 efim20036 mn-3503 fins5568 110.807 bcpm000028 info6030 bma0092 bcpm0054 math20212 ce335 cs365 cenv6141 ftec5580 math2010 ec3450 comm1170 ecmt1010 csci-ua.0480-003 econ12-200 ib3960 ectb60h3f cs247—assignment tk3163 ics3u ib3j80 comp20008 comp9334 eppd1063 acct2343 cct109 isys1055/3412 math350-real math2014 eec180 stat141b econ2101 msinm014/msing014/msing014b fit2004 comp643 bu1002 cm2030
联系我们
EMail: 99515681@qq.com
QQ: 99515681
留学生作业帮-留学生的知心伴侣!
工作时间:08:00-21:00
python代写
微信客服:codinghelp
站长地图