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;
}
相关推荐
sewinger9 分钟前
区间合并算法详解
算法
CSP1263612 分钟前
特别节目————集训总结
c++
XY.散人12 分钟前
初识算法 · 滑动窗口(1)
算法
程序猿阿伟14 分钟前
《C++游戏人工智能开发:开启智能游戏新纪元》
c++·人工智能·游戏
韬. .34 分钟前
树和二叉树知识点大全及相关题目练习【数据结构】
数据结构·学习·算法
野草y34 分钟前
数据结构(7.4_1)——B树
数据结构·b树
Word码39 分钟前
数据结构:栈和队列
c语言·开发语言·数据结构·经验分享·笔记·算法
代码雕刻家40 分钟前
数据结构-3.10.队列的应用
服务器·数据结构
五花肉村长42 分钟前
数据结构-队列
c语言·开发语言·数据结构·算法·visualstudio·编辑器
秋落风声43 分钟前
【数据结构】---图
java·数据结构··graph