当前位置:   article > 正文

leetcode547. 省份数量

547. 省份数量

有 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

思路:

1、我们这道题因为是要找到城市的周边,而在矩阵中第i行和第i列都表示这个城市,因此矩阵是对称的,我们只需要遍历行或者列就行。
2、假如我们先从第0行开始遍历,为了防止重复遍历,我们需要一个visited[]来判断是否已经遍历过了。同时我们还需要一个值用来记录province的数量。
3、首先找到第一个未被遍历的城市,然后进入dfs。
4、dfs中的 j 如果未被遍历同时isConnected值为1,说明和第 i 个城市连通。标记为visited
5、那与第 j 个城市连通,自然也与第 i 个城市也连通,所以继续向下遍历。
而所有递归完成后与第 i 个城市连通的所有城市都为visited,再查找到的就是新的省份了。

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

void dfs(vector<vector<int>>& graph, int i, vector<bool>& visited) {
	
	for (int j = 0; j < graph[0] .size(); j++)
	{
		if (graph[i][j] == 1 /*&& i != j */&& visited[j] == false)//找到顶点i的一个未访问相邻点j
		{
			visited[j] = true;
			dfs(graph, j, visited);
		}
	}
}

int findCircleNum(vector<vector<int>>& isConnected) {
	int size = isConnected.size();
	vector<bool> visited(size,false);//因为邻接矩阵表示无向图时候的对称性,用一维数组表示
	int res = 0;
	for (int i = 0; i < size; i++)
	{
		if (visited[i] == false)
		{
			visited[i] = true;
			res++;
			dfs(isConnected, i, visited);
		}
	}
	return res;
}

int main() {
	vector<vector<int>> graph{ {1,1,0},{1,1,0},{0,0,1} };
	int res = findCircleNum(graph);
	cout << res << endl;
	return 0;
}
  • 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
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/531721
推荐阅读
相关标签
  

闽ICP备14008679号