-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathBipartiteGraph.java
107 lines (89 loc) · 3 KB
/
BipartiteGraph.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/*
* @Bipartite Graph
* A Bipartite Graph is a graph whose vertices can be divided into two independent sets, U and V
* such that every edge (u, v) either connects a vertex form U to V or a Vertex from V to U. in
* other worlds, for every edge(u,v), either u belongs to U and v, or u belongs to V and v to U.
* We can also say that there is no edge that connects vertices of same set.
*/
import java.util.*;
import java.util.LinkedList;
public class BipartiteGraph {
static class Edge {
int src;
int dest;
Edge(int src, int dest) {
this.src = src;
this.dest = dest;
}
}
public static void bfs(ArrayList<Edge>[] graph) {
boolean[] vis = new boolean[graph.length];
Queue<Integer> q = new LinkedList<>();
q.add(0);
while (!q.isEmpty()) {
int curr = q.remove();
if (!vis[curr]) {
System.out.print(curr + " ");
vis[curr] = true;
for (int i = 0; i < graph[curr].size(); i++) {
Edge e = graph[curr].get(i);
q.add(e.dest);
}
}
}
}
public static boolean isBipartite(ArrayList<Edge>[] graph) {
int col[] = new int[graph.length];
for (int i = 0; i < col.length; i++) {
col[i] = -1; // no color
}
Queue<Integer> q = new LinkedList<>();
for (int i = 0; i < graph.length; i++) {
if (col[i] == -1) { // BFS
q.add(i);
col[i] = 0; // yellow
while (!q.isEmpty()) {
int curr = q.remove();
for (int j = 0; j < graph[curr].size(); j++) {
Edge e = graph[curr].get(j);
if (col[e.dest] == -1) {
int nextCol = col[curr] == 0 ? 1 : 0;
col[e.dest] = nextCol;
q.add(e.dest);
} else if (col[curr] == col[e.dest]) {
return false; // NOT bipartite
}
}
}
}
}
return true;
}
public static void main(String[] args) {
int v = 5;
ArrayList<Edge>[] graph = new ArrayList[v];
for (int i = 0; i < graph.length; i++) {
graph[i] = new ArrayList<>();
}
// 0 Edge
graph[0].add(new Edge(0, 1));
graph[0].add(new Edge(0, 2));
// 1 Edge
graph[1].add(new Edge(1, 0));
graph[1].add(new Edge(1, 3));
// 2 Edge
graph[2].add(new Edge(2, 0));
graph[2].add(new Edge(2, 4));
// 3 Edge
graph[3].add(new Edge(3, 1));
// graph[3].add(new Edge(3, 4));
// 4 Edge
// graph[4].add(new Edge(4, 3));
graph[4].add(new Edge(4, 2));
System.out.println(isBipartite(graph));
}
}
/*
* Output:
* true
*/