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;
}
相关推荐
技术小黑2 小时前
CNN算法实战系列03 | DenseNet121算法实战与解析
pytorch·深度学习·算法·cnn
困意少年2 小时前
队列:先进先出为什么特别适合“流程推进”这类问题
数据结构
超级小星星2 小时前
C 语言结构体内存对齐深度解析:从概念到实战
c语言·开发语言
wearegogog1232 小时前
三电平SVPWM逆变器仿真指南
单片机·算法
笨笨饿2 小时前
74_SysTick滴答定时器中断
c语言·开发语言·人工智能·单片机·嵌入式硬件·算法·学习方法
2501_921960852 小时前
协同本体论 V4.2+:离散关系拓扑涌现连续时空几何的数值验证
数据结构·人工智能·重构
科芯创展3 小时前
XZ4058B/C,20V,外置MOS,8.4V/8.7V开关充电芯片 宽范围电源电压:8.9V~20V-(电池充电电压:8.4V/8.7V)
c语言·开发语言
WiChP3 小时前
【V0.1B9】从零开始的2D游戏引擎开发之路
c++·游戏引擎
pkowner3 小时前
若依分页问题及解决方法
java·前端·算法
呃呃本3 小时前
算法题(栈)
算法