-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathp140.java
88 lines (74 loc) · 2.44 KB
/
p140.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*Given a weighted, directed and connected graph of V vertices and E edges, Find the shortest distance of all the vertex's from the source vertex S.
Note: If the Graph contains a negative cycle then return an array consisting of only -1.
Example 1:
Input:
E = [[0,1,9]]
S = 0
Output:
0 9
Explanation:
Shortest distance of all nodes from
source is printed.
Example 2:
Input:
E = [[0,1,5],[1,0,3],[1,2,-1],[2,0,1]]
S = 2
Output:
1 6 0
Explanation:
For nodes 2 to 0, we can follow the path-
2-0. This has a distance of 1.
For nodes 2 to 1, we cam follow the path-
2-0-1, which has a distance of 1+5 = 6,
Your Task:
You don't need to read input or print anything. Your task is to complete the function bellman_ford( ) which takes a number of vertices V and an E-sized list of lists of three integers where the three integers are u,v, and w; denoting there's an edge from u to v, which has a weight of w and source node S as input parameters and returns a list of integers where the ith integer denotes the distance of an ith node from the source node.
If some node isn't possible to visit, then its distance should be 100000000(1e8). Also, If the Graph contains a negative cycle then return an array consisting of only -1.
Expected Time Complexity: O(V*E).
Expected Auxiliary Space: O(V).
Constraints:
1 ≤ V ≤ 500
1 ≤ E ≤ V*(V-1)
-1000 ≤ adj[i][j] ≤ 1000
0 ≤ S < V*/
/*
* edges: vector of vectors which represents the graph
* S: source vertex to start traversing graph with
* V: number of vertices
*/
class Solution {
static int[] bellman_ford(int V, ArrayList<ArrayList<Integer>> edges, int S) {
int dist[]=new int[V];
int negarr[];
boolean neg=false;
dist[S]=0;
for(int i=0;i<V;i++){
if(i!=S){
dist[i]=100000000;
}
}
for(int k=0;k<V-1;k++){
for(ArrayList<Integer> ls:edges){
int u=ls.get(0);
int v=ls.get(1);
int c=ls.get(2);
if(dist[u]+c<dist[v]){
dist[v]=dist[u]+c;
}
}
}
for(ArrayList<Integer> ls:edges){
int u=ls.get(0);
int v=ls.get(1);
int c=ls.get(2);
if(dist[u]+c<dist[v]){
neg=true;
}
}
if(neg){
negarr=new int[1];
negarr[0]=-1;
return negarr;
}
return dist;
}
}