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;
}
相关推荐
循着风10 小时前
二叉树的多种遍历方式
数据结构·算法
老猿讲编程14 小时前
C++中的奇异递归模板模式CRTP
开发语言·c++
.格子衫.15 小时前
022数据结构之树状数组——算法备赛
数据结构·算法·1024程序员节
黑科技Python15 小时前
生活中的“小智慧”——认识算法
学习·算法·生活
Yupureki15 小时前
从零开始的C++学习生活 16:C++11新特性全解析
c语言·数据结构·c++·学习·visual studio
紫荆鱼16 小时前
设计模式-迭代器模式(Iterator)
c++·后端·设计模式·迭代器模式
ScilogyHunter16 小时前
C语言标准库完全指南
c语言·开发语言
sali-tec16 小时前
C# 基于halcon的视觉工作流-章52-生成标定板
开发语言·图像处理·人工智能·算法·计算机视觉
IT古董16 小时前
【第五章:计算机视觉-项目实战之推荐/广告系统】2.粗排算法-(4)粗排算法模型多目标算法(Multi Task Learning)及目标融合
人工智能·算法·1024程序员节
熬了夜的程序员16 小时前
【LeetCode】89. 格雷编码
算法·leetcode·链表·职场和发展·矩阵