leetcode_547 省份数量

该题主要运用了图的连通性 接着使用染色法解决该问题

染色法:标记所有节点为false 访问后 将其标记位true

复制代码
class Solution {
    int n;            // 代表n个数据
    bool colors[201]; // 标记是否访问到

    void dfs(vector<vector<int>>& isConnected, int u) { // u代表从哪个点开始访问
        if (colors[u]) { // 递归终止条件:该节点已经被访问
            return;
        }
        colors[u] = true; // 标记位以访问

        for (int i = 0; i < n; ++i) {
            if (isConnected[u][i]) {
                dfs(isConnected, i);
            }
        }
    }

public:
    int findCircleNum(vector<vector<int>>& isConnected) {
        n = isConnected.size();
        memset(colors, false, sizeof(isConnected)); // 初始化全部为未访问
        int cnt = 0;
        for (int i = 0; i < isConnected.size(); ++i) {
            if (colors[i] == false) {  //只访问未访问过的节点
                dfs(isConnected, i);
                ++cnt;
            }
        }
        return cnt;
    }
};

在递归过程中 开始由于判断错了一个条件 导致不能通过全部案例

复制代码
for (int i = 0; i < n; ++i) {
            if (isConnected[u][i]) {
                dfs(isConnected, i);
            }
        }

写成了

复制代码
for (int i = u + 1; i < n; ++i) {
            if (isConnected[u][i]) {
                dfs(isConnected, i);
            }
        }

我想的是这个节点既然是连通的 那么必将是先访问数字小的节点 在访问数字大的节点 我这么写之后 错了 我以为是 数组越界的问题 但是这个i如果超出了数组的边界不会进去for循环内部 我又把 这一句改为 i = u 我觉得就是没有必要去继续访问比自己小的节点了 但是忽略了一个问题 就是小的节点可能直接和一个更大的节点相连 并没有和另一个小的相连 这样子的话 传入的起始节点就会很大 但是大的节点和另一个小的相连了 但是访问不到 导致得到结果偏大的问题

例如下面的这个案例

如果按照错误的执行 将是这样子的 执行顺序

得到的结果会是2 正确是1

正确的执行顺序

相关推荐
fu的博客4 分钟前
【数据结构7】链式栈实现
数据结构·算法
xiaoye-duck4 分钟前
《算法题讲解指南:优选算法-双指针》--01移动零,02复写零
c++·算法
田里的水稻9 分钟前
LPC_激光点云定位(LSLAM)-(IPC)
人工智能·算法·数学建模·机器人·自动驾驶
额,不知道写啥。23 分钟前
P5314 ODT(毒瘤树剖)
数据结构·c++·算法
CHANG_THE_WORLD24 分钟前
深入指针5:回调函数与泛型排序
数据结构·算法
今儿敲了吗29 分钟前
24| 字符串
数据结构·c++·笔记·学习·算法
Wect41 分钟前
LeetCode 105. 从前序与中序遍历序列构造二叉树:题解与思路解析
前端·算法·typescript
小雨中_1 小时前
2.5 动态规划方法
人工智能·python·深度学习·算法·动态规划
智算菩萨1 小时前
【Python小游戏】基于Pygame的递归回溯迷宫生成与BFS寻路实战:从算法原理到完整游戏架构的深度解析
python·算法·pygame
测绘工程师2 小时前
【排序算法】冒泡排序
数据结构·算法·排序算法