neuq-acm预备队训练week 9 P3916 图的遍历

题目描述

给出 N 个点,M 条边的有向图,对于每个点 v,求 A(v) 表示从点 v 出发,能到达的编号最大的点。

题目限制

输入格式

第 1 行 2 个整数N,M,表示点数和边数。

接下来 M 行,每行 22 个整数 Ui​,Vi​,表示边(Ui​,Vi​)。点用1,2,...,N 编号。

输出格式

一行 N 个整数 A(1),A(2),...,A(N)。

输入输出样例

解题思路

这题可以反向建边和dfs

AC代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,m,a[100010];
vector<int> g[100010];
void dfs(int x,int d);
int main()
{
    int u,v;
    cin>>n>>m;
    for(int i=1;i<=m;i++)
    {
        cin>>u>>v;
        g[v].push_back(u);
    }
    for(int i=n;i;i--)
        dfs(i,i);
    for(int i=1;i<=n;i++)
        printf("%d ",a[i]);
    return 0;
}
void dfs(int x,int d)
{
    if(a[x])
        return ;
    a[x]=d;
    for(int i=0;i<g[x].size();i++)
        dfs(g[x][i],d);
}
相关推荐
被开发耽误的大厨1 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang0073212 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆3 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)3 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野5 小时前
刷题:数组
数据结构·算法
tankeven5 小时前
HJ182 画展布置
c++·算法
CS_Zero7 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵7 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang7 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
Ulyanov7 小时前
像素迷宫:路径规划算法的可视化与实战
大数据·开发语言·python·算法