联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2020-12-04 09:24

1. (50 points) Ford-Fulkerson

We will implement the Ford-Fulkerson algorithm to calculate the Maximum Flow of a directed

weighted graph. Here, you will use the files WGraph.java and FordFulkerson.java,

which are available on the course website. Your role will be to complete two methods in

the template FordFulkerson.java.

The file WGraph.java is similar to the file that you used in your previous assignment to

build graphs. The only dierences

are the addition of setter and getter methods for the

Edges and the addition of the parameters “source” and “destination”. There is also an

additional constructor that will allow the creation of a graph cloning a WGraph object.

Graphs are encoded using a similar format than the one used in the previous assignment.

The only dierence

is that now the first line corresponds to two integers, separated by

one space, that represent the “source” and the “destination” nodes. An example of such

file can be found on the course website in the file ff2.txt. These files will be used

as an input in the program FordFulkerson.java to initialize the graphs. This graph

corresponds to the same graph depicted in [CLRS2009] page 727.

Your task will be to complete the two static methods (fordfulkerson WGraph graph)

and pathDFS(Integer source, Integer destination, WGraph graph). The second

method pathDFS finds a path via Depth First Search (DFS) between the nodes “source”

and “destination” in the “graph”. You must return an ArrayList of Integers with the

list of unique nodes belonging to the path found by the DFS. The first element in the

list must correspond to the “source” node, the second element in the list must be the

second node in the path, and so on until the last element (i.e., the “destination” node) is

stored. If the path does not exist, return an empty path. The method fordfulkerson

must compute an integer corresponding to the max flow of the “graph”, as well as the

graph encoding the assignment associated with this max flow.

Once completed, compile all the java files and run the command line java FordFulkerson

ff2.txt. Your program will output a String containing the relevant information. An

example of the expected output is available in the file ff2testout.txt. This output

keeps the same format than the file used to build the graph; the only dierence

is that

the first line now represents the maximum flow (instead of the “source” and “destination”

nodes). The other lines represent the same graph with the weights updated to the

values that allow the maximum flow. The file ff226testout.txt represents the answer

to the example showed in [CLRS2009] Page 727. You are invited to run other examples

of your own to verify that your program is correct.

2. (50 points) Bellman-Ford

We want to implement the Bellman-Ford algorithm for finding the shortest path in

a graph where edges can have negative weights. Once again, you will use the object

WGraph. Your task is to complete the method BellmanFord(WGraph g, int source)

and shortestPath(int destination) in the file BellmanFord.java.

The method BellmanFord takes an object WGraph named g as an input and an integer

that indicates the source of the paths. If the input graph g contains a negative cycle,

then the method should throw an exception (see template). Otherwise, it will return

COMP 251 - HW3 Page 4 of 6 Fall 2020


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp