92 lines
2.5 KiB
Java
92 lines
2.5 KiB
Java
//
|
||
//
|
||
// 有 n 个城市,其中一些彼此相连,另一些没有相连。如果城市 a 与城市 b 直接相连,且城市 b 与城市 c 直接相连,那么城市 a 与城市 c 间接相连
|
||
//。
|
||
//
|
||
// 省份 是一组直接或间接相连的城市,组内不含其他没有相连的城市。
|
||
//
|
||
// 给你一个 n x n 的矩阵 isConnected ,其中 isConnected[i][j] = 1 表示第 i 个城市和第 j 个城市直接相连,而
|
||
//isConnected[i][j] = 0 表示二者不直接相连。
|
||
//
|
||
// 返回矩阵中 省份 的数量。
|
||
//
|
||
//
|
||
//
|
||
// 示例 1:
|
||
//
|
||
//
|
||
//输入:isConnected = [[1,1,0],[1,1,0],[0,0,1]]
|
||
//输出:2
|
||
//
|
||
//
|
||
// 示例 2:
|
||
//
|
||
//
|
||
//输入:isConnected = [[1,0,0],[0,1,0],[0,0,1]]
|
||
//输出:3
|
||
//
|
||
//
|
||
//
|
||
//
|
||
// 提示:
|
||
//
|
||
//
|
||
// 1 <= n <= 200
|
||
// n == isConnected.length
|
||
// n == isConnected[i].length
|
||
// isConnected[i][j] 为 1 或 0
|
||
// isConnected[i][i] == 1
|
||
// isConnected[i][j] == isConnected[j][i]
|
||
//
|
||
//
|
||
//
|
||
// Related Topics 深度优先搜索 广度优先搜索 并查集 图
|
||
// 👍 595 👎 0
|
||
|
||
package leetcode.editor.cn;
|
||
|
||
import com.code.leet.entiy.TwoArray;
|
||
|
||
import java.util.LinkedList;
|
||
import java.util.Queue;
|
||
|
||
//547:省份数量
|
||
class NumberOfProvinces {
|
||
public static void main(String[] args) {
|
||
//测试代码
|
||
Solution solution = new NumberOfProvinces().new Solution();
|
||
TwoArray twoArray = new TwoArray("[[1,1,0],[1,1,0],[0,0,1]]", true);
|
||
System.out.println(solution.findCircleNum(twoArray.getArr()));
|
||
}
|
||
|
||
//力扣代码
|
||
//leetcode submit region begin(Prohibit modification and deletion)
|
||
class Solution {
|
||
public int findCircleNum(int[][] isConnected) {
|
||
int length = isConnected.length;
|
||
boolean[] use = new boolean[length];
|
||
|
||
int count = 0;
|
||
Queue<Integer> queue = new LinkedList<>();
|
||
for (int i = 0; i < length; i++) {
|
||
if (!use[i]) {
|
||
count++;
|
||
queue.add(i);
|
||
use[i] = true;
|
||
while (!queue.isEmpty()) {
|
||
int num = queue.poll();
|
||
for (int j = 0; j < length; j++) {
|
||
if (isConnected[num][j] == 1 && !use[j]) {
|
||
use[j] = true;
|
||
queue.add(j);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return count;
|
||
}
|
||
}
|
||
//leetcode submit region end(Prohibit modification and deletion)
|
||
|
||
} |