forked from IDeserve/learn
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFriendCirclesGraph
63 lines (48 loc) · 1.74 KB
/
FriendCirclesGraph
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
package questions.saurabh;
/**
* <b>IDeserve <br>
* <a href="https://www.youtube.com/c/IDeserve">https://www.youtube.com/c/IDeserve</a>
* <br><br>
* Friend Circles Graph Problem:</b><br>
* There are n students in a class.
* Every student can have 0 or more friends.
* If A is a friend of B and B is a friend of C then A and C are also friends.
* So we define a friend circle as a group of students who are friends as given by above definition. <br>
* Given an nXn-matrix friends which consists of characters Y or N.
* If friends[i][j]=Y, then ith and jth students are friends, friends[i][j]=N, then i and j are not friends.
* Find the total number of such friend circles in the class.
* <br><br>
* <a href="https://www.youtube.com/watch?v=1XuCGYE56T0">Friend Circle Problem Youtube Link</a>
* @author Saurabh
*
*/
public class FriendCirclesGraph {
public static void main(String[] args) {
char[][] friends = {"YYNN".toCharArray(), "YYYN".toCharArray(), "NYYN".toCharArray(), "NNNY".toCharArray()};
System.out.println(getFriendCircles(friends));
}
public static int getFriendCircles(char[][] friends) {
if (friends == null || friends.length < 1)
return 0;
int noOfCircles = 0;
boolean visited[] = new boolean[friends.length];
for (int i = 0; i < visited.length; i++)
visited[i] = false;
for (int i = 0; i < friends.length; i++) {
if (!visited[i]) {
noOfCircles++;
visited[i] = true;
findFriends(friends, visited, i);
}
}
return noOfCircles;
}
public static void findFriends(char[][] friends, boolean[] visited, int id) {
for (int i = 0; i < friends.length; i++) {
if (!visited[i] && i != id && 'Y' == friends[id][i]) {
visited[i] = true;
findFriends(friends, visited, i);
}
}
}
}