Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

(Short & quick) Need help with this Java problem (will upvote correct answer): import stdlib.*; // You need only change the constructor. // You can

(Short & quick) Need help with this Java problem (will upvote correct answer):

import stdlib.*;

// You need only change the constructor. // You can also change the main method. // But you should not change eccentricity(), diameter(), radius(), center() or isCenter() // You can (and should!) add more private methods (such as bfs or dfs) public class MyGraphProperties { int[] eccentricity; int diameter; int radius; int center;

// Constructor can be linear in G.V() * G.E() public MyGraphProperties(Graph G) { this.eccentricity = new int[G.V()]; int diameter = Integer.MIN_VALUE; int radius = Integer.MAX_VALUE; int center = -1; // If G.V()==0, then these are the correct values. // If G is not connected, you should throw a new IllegalArgumentException() // I suggest that you first get it to work for a connected graph // This will require that you traverse the graph starting from some node (say 0) // You can then adjust your code so that it throws an exception in the case that all nodes are not visited

// TODO // compute the eccentricity, diameter, radius and center // The center of the graph is not unique, set center to SOME center --- it does not matter which one this.diameter = diameter; this.radius = radius; this.center = center; }

// Do not change the following constant time methods public int eccentricity(int v) { return eccentricity[v]; } public int diameter() { return diameter; } public int radius() { return radius; } public int center() { return center; } public boolean isCenter(int v) { return eccentricity[v] == radius; }

public static void main(String[] args) { //Graph G = new Graph(new In("data/tinyG.txt")); // this is non-connected -- should throw an exception //Graph G = GraphGenerator.connected (10, 20, 2); // Random non-connected graph -- should throw an exception

Graph G = new Graph(new In("data/tinyCG.txt")); // diameter=2, radius=2, every node is a center //Graph G = GraphGenerator.binaryTree (10); // A complete binary tree //Graph G = GraphGenerator.path (10); // A path -- diameter=V-1 //Graph G = GraphGenerator.connected (20, 400); // Random connected graph

StdOut.println(G); G.toGraphviz ("g.png");

MyGraphProperties gp = new MyGraphProperties(G); for (int v = 0; v < G.V(); v++) StdOut.format ("eccentricity of %d: %d ", v, gp.eccentricity (v)); StdOut.format ("diameter=%d, radius=%d, center=%d ", gp.diameter(), gp.radius (), gp.center ()); } }

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image

Step: 3

blur-text-image

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

XML Data Management Native XML And XML Enabled Database Systems

Authors: Akmal Chaudhri, Awais Rashid, Roberto Zicari, John Fuller

1st Edition

ISBN: 0201844524, 978-0201844528

More Books

Students also viewed these Databases questions

Question

Explain Coulomb's law with an example

Answered: 1 week ago

Question

What is operating system?

Answered: 1 week ago

Question

What is Ohm's law and also tell about Snell's law?

Answered: 1 week ago