2024/1/24 图的基本应用

目录

查找文献

图的遍历


查找文献

P5318 【深基18.例3】查找文献 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:这道题就是先建图,然后dfs深搜输出,bfs宽搜输出就行了

完整代码:

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
const int N = 1e6 + 10;
std::vector<std::vector<int>> g(N);//建一个二维数组,输入x,y 把y放进x里面
int n, m;
bool vis[N]{};
void dfs(int cur) {
    std::cout << cur << " ";//到了哪一层就输出哪一层
    vis[cur] = true;
    for (int i = 0; i < (int) g[cur].size(); i++)//遍历这一个节点连接的所有文献
    {
        if (vis[g[cur][i]] == false)//如果还没有输出
            dfs(g[cur][i]);//继续搜索
    }
}
void bfs() {
    memset(vis, 0, sizeof(vis));//清空上一层dfs的
    std::queue<int> q;//建一个队列
    q.push(1);//因为是从1号节点开始所以把1放进去
    vis[1] = true;//标记,后面的就不能走这条路了
    while (!q.empty()) {
        int cur = q.front();
        q.pop();
        std::cout << cur << " ";
        for (int i = 0; i < (int) g[cur].size(); i++) {
            if (vis[g[cur][i]] == false) {
                q.push(g[cur][i]);
                vis[g[cur][i]] = true;
            }
        }
    }
}
signed main() {
    std::cin >> n >> m;//输入数据
    for (int i = 1; i <= m; i++) {
        int x, y;
        std::cin >> x >> y;
        g[x].push_back(y);//把y放进x里面
    }
    for (int i = 1; i <= n; i++) {
        std::sort(g[i].begin(), g[i].end());//一个节点可能连了多个文献,所以对这一个节点的文献进行排序
    }
    dfs(1);//从1号点开始搜索
    std::cout << "\n";
    bfs();
    return 0;
}

图的遍历

P3916 图的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:这道题反向建图,然后依次遍历,输出答案就可以了

完整代码:

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
const int N = 1e5 + 10;
std::vector<std::vector<int>> g(N);
int n, m;
int a[N];
void dfs(int cur,int d)
{
    if(a[cur]!=0)
        return;
    a[cur]=d;
    for(int i = 0;i < g[cur].size();i ++)
    {
        dfs(g[cur][i],d);
    }
}
signed main() {
    std::cin >> n >> m;
    for (int i = 1; i <= m; i++) {
        int x, y;
        std::cin >> x >> y;
        g[y].push_back(x);
    }
    for (int i = n; i >= 1; i--) {
        dfs(i,i);
    }
    for(int i = 1;i <= n;i ++)
    {
        std::cout<<a[i]<<" ";
    }
    return 0;
}
相关推荐
维构lbs智能定位13 分钟前
蓝牙信标、UWB等主流室内定位无线技术的参数对比、核心算法和选型指南详解(二)
算法·蓝牙信标·uwb·主流室内定位无线技术
喵了meme25 分钟前
C语言实战2
c语言·开发语言·网络
charlie11451419131 分钟前
现代C++工程实践:简单的IniParser3——改进我们的split
开发语言·c++·笔记·学习
fish_xk32 分钟前
c++的引用和类的初见
开发语言·c++
灰灰勇闯IT1 小时前
【探索实战】Kurator多集群统一应用分发实战:从环境搭建到业务落地全流程
算法
鱼在树上飞1 小时前
乘积最大子数组
算法
H_z___1 小时前
Codeforces Round 1070 (Div. 2) A~D F
数据结构·算法
晨尘光2 小时前
【Windows 下FlatBuffers 编译.fbs文件并应用】
c++·windows
网易独家音乐人Mike Zhou2 小时前
【嵌入式模块芯片开发】LP87524电源PMIC芯片配置流程,给雷达供电的延时上电时序及API函数
c语言·stm32·单片机·51单片机·嵌入式·电源·毫米波雷达
自学小白菜2 小时前
每周刷题 - 第三周 - 双指针专题 - 02
python·算法·leetcode