题解 | #岛屿数量#

岛屿数量

http://www.nowcoder.com/practice/0c9664d1554e466aa107d899418e814e

这个题是典型的dfs的题,需要注意的是不要重复查找。所以需要对查找过的岛屿进行标记。

class Solution {
public:
    /**
     * 判断岛屿数量
     * @param grid char字符型vector<vector<>> 
     * @return int整型
     */
    int solve(vector<vector<char> >& grid) {
        int count = 0;
        // write code here
        vector<vector<int>> search(grid.size(),vector<int> (grid[0].size(),false));
        for(int i=0;i<grid.size();i++){
            for(int j=0;j<grid[0].size();j++){
                if(search[i][j]==1 || grid[i][j] == '0'){
                    search[i][j] = 1;
                    continue;
                }
                
                dfs(grid, search, i, j);
                count++;
            }
        }
        
        return count;
    }
    
    void dfs(vector<vector<char> >& grid,vector<vector<int> >& search,int i,int j){
        if(search[i][j] == 1){
            return;
        }
        search[i][j] = 1;
        if(j-1 >= 0 && grid[i][j-1] == '1'){
            dfs(grid, search, i, j-1);
        }
        
        if(i-1 >= 0 && grid[i-1][j] == '1'){
            dfs(grid, search, i-1, j);
        }
        
        if(i+1 < grid.size() && grid[i+1][j] =='1'){
            dfs(grid, search, i+1, j);
        }
        
        if(j+1 < grid[0].size() && grid[i][j+1] == '1'){
            dfs(grid, search, i, j+1);
        }
    }
};


全部评论

相关推荐

12-26 14:44
复旦大学 Java
点赞 评论 收藏
分享
11-28 16:00
已编辑
武汉理工大学 Java
Tom哥981:这份简历是“短期项目硬堆中大型系统技术”的“技术炫技式造假模板”,槽点密集到能当反面教材: ### 1. 「项目时长」和「技术密度」严重脱节,造假痕迹焊死在简历上 两个项目时长分别是**3个月、2个月**,但堆了Spring AI、Elasticsearch、MinIO、Kafka、ShardingSphere、Docker、Sentinel等近20个中大型项目才用的技术——正常情况下,光把这些中间件的文档看完+环境搭好,3个月都不够,更别说实现“AI多轮对话、分库分表、RBAC权限、大模型调用”这些功能。 说白了:你这不是“做项目”,是把“后端技术栈清单”往项目里硬塞,明摆着“只调用了API,没碰过核心逻辑”。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务