代码随想录算法训练营 | 图论 | DFS

98. 所有可达路径// DFS

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

vector<vector<int>> result;
vector<int> path;

void dfs(const vector<list<int>> &graph, int i, int target) {
  if (i == target) {
    result.push_back(path);
    return;
  }
  for (int nums : graph[i]) {
    path.push_back(nums);
    dfs(graph, nums, target);
    path.pop_back();
  }
}

int main() {
  int n, m;
  cin >> n >> m;
  vector<list<int>> graph(n + 1);
  int temp, next;
  for (int i = 0; i < m; i++) {
    cin >> temp >> next;
    graph[temp].push_back(next);
  }
  path.push_back(1);
  dfs(graph, 1, n);
  if (result.size() == 0)
    cout<<-1<<endl;
  for (int i = 0; i < result.size(); i++) {
    for (int j = 0; j < result[i].size() - 1; j++) {
      cout << result[i][j] << " ";
    }
    cout << result[i][result[i].size() - 1] << endl;
  }
}

99. 岛屿数量//。。感觉这题没必要拘泥于用什么搜索。。

复制代码
#include<bits/stdc++.h>
using namespace std;


void DFSfindsameIsland(vector<vector<bool>>& finded,const vector<vector<int>>& graph,int a,int b){
    if(a<0||b<0||a>graph.size()-1||b>graph[a].size()-1) return;
    else if(graph[a][b]==0) return;
    else if(graph[a][b]==1){
        if(finded[a][b]==false){
            finded[a][b]=true;
            DFSfindsameIsland(finded,graph,a,b+1);
            DFSfindsameIsland(finded,graph,a+1,b);
            DFSfindsameIsland(finded,graph,a,b-1);
            DFSfindsameIsland(finded,graph,a-1,b); 
        }
        else return;
    }
}
int main(){
    int i,j;
    cin>>i>>j;
    vector<vector<int>> graph(i,vector<int> (j));
    for(int a=0;a<i;a++){
        for(int b=0;b<j;b++){
            cin>>graph[a][b];
        }
    }
    vector<vector<bool>> finded(i,vector<bool> (j,false));
    int result=0;
    for(int a=0;a<i;a++){
        for(int b=0;b<j;b++){
            if(graph[a][b]==1&&!finded[a][b]){
                result++;
                DFSfindsameIsland(finded,graph,a,b);
            }  
        }
    }
    cout<<result<<endl;     
}

100. 岛屿的最大面积//偷懒了。随便拿上一题的代码改改就交了

复制代码
#include<bits/stdc++.h>
using namespace std;


int DFSfindsameIsland(vector<vector<bool>>& finded,const vector<vector<int>>& graph,int a,int b){
    if(a<0||b<0||a>graph.size()-1||b>graph[a].size()-1) return 0;
    else if(graph[a][b]==0) return 0;
    else{
        if(finded[a][b]==false){
            int result=1;
            finded[a][b]=true;
            result+=DFSfindsameIsland(finded,graph,a,b+1);
            result+=DFSfindsameIsland(finded,graph,a+1,b);
            result+=DFSfindsameIsland(finded,graph,a,b-1);
            result+=DFSfindsameIsland(finded,graph,a-1,b);
            return result;
        }
        else return 0;
    }
}
int main(){
    int i,j;
    cin>>i>>j;
    vector<vector<int>> graph(i,vector<int> (j));
    for(int a=0;a<i;a++){
        for(int b=0;b<j;b++){
            cin>>graph[a][b];
        }
    }
    vector<vector<bool>> finded(i,vector<bool> (j,false));
    int result=0;int maxaera=0;
    for(int a=0;a<i;a++){
        for(int b=0;b<j;b++){
            if(graph[a][b]==1&&!finded[a][b]){
                maxaera=max(maxaera,DFSfindsameIsland(finded,graph,a,b));
            }  
        }
    }
    cout<<maxaera<<endl;     
}
相关推荐
eachin_z38 分钟前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
机器学习之心1 小时前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。1 小时前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879672 小时前
省略号和可变参数模板
开发语言·c++·算法
飞川撸码3 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习4 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910134 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题5 小时前
算法练习-回溯
算法
眼镜哥(with glasses)5 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯