首页 > 其他分享 >PTA 那就别担心了

PTA 那就别担心了

时间:2023-03-22 20:36:03浏览次数:22  
标签:终点 const int ed 担心 st dfs PTA

PTA 那就别担心了

给定一个有向无环图,给出起点\(st\)和终点\(ed\),问从起点出发的所有路径是否都能到达终点,并且让你求出从起点到终点的不同路径数量

\(DFS\)记忆化搜索

  1. 对于第一个问题我们只要在\(dfs\)时判断一个点如果出度为\(0\),并且该点不是终点,那么说明从起点出发的该条路径无法到达终点

  2. 对于第二个问题,我们考虑记忆化搜索\(dp\)解决

状态表示:\(f[u]\):代表从\(u\)点出发能够到达终点的路径数量

状态属性:数量

状态转移:\(f[u] = f[v_1]+f[v_2]+...f[v_k]\)

状态初始:\(f[ed] = 1\)(终点到终点的路径数量为1),其余\(f[u]=0\)

答案呈现:\(f[st]\)

#include <bits/stdc++.h>
#define Zeoy std::ios::sync_with_stdio(false), std::cin.tie(0), std::cout.tie(0)
#define debug(x) cerr << #x << '=' << x << endl
#define all(x) (x).begin(), (x).end()
#define int long long
#define mpk make_pair
#define endl '\n'
using namespace std;
typedef unsigned long long ULL;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
const int inf = 0x3f3f3f3f;
const ll INF = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9 + 7;
const double eps = 1e-9;
const int N = 5e2 + 10, M = 4e5 + 10;

int n, m;
vector<int> g[N];
int f[N]; // f[i]:代表从i出发到终点的路径数
int st, ed;
int du[N]; // 出度
bool flag;

int dfs(int u)
{
    if (du[u] == 0 && u != ed)
        flag = false;
    if (f[u])
        return f[u];
    int t = 0;
    for (auto v : g[u])
        t += dfs(v);
    return f[u] = t;
}

void solve()
{
    cin >> n >> m;
    for (int i = 1, u, v; i <= m; ++i)
    {
        cin >> u >> v;
        g[u].push_back(v);
        du[u]++;
    }
    cin >> st >> ed;
    flag = true;
    f[ed] = 1;
    dfs(st);
    cout << f[st] << " ";
    if (flag == true)
        cout << "Yes" << endl;
    else
        cout << "No" << endl;
}
signed main(void)
{
    Zeoy;
    int T = 1;
    // cin >> T;
    while (T--)
    {
        solve();
    }
    return 0;
}

标签:终点,const,int,ed,担心,st,dfs,PTA
From: https://www.cnblogs.com/Zeoy-kkk/p/17245327.html

相关文章

  • PTA 红豆生南国
    题目:有诗云:相思(王维唐)红豆生南国,春来发几枝。愿君多采撷,此物最相思。 那么,我们来采红豆吧!假设红豆树是这个样子的:这种红豆树的特点是:每个结点都有一......
  • 密码学SAT入门文献1——Algebraic and Logic Solving Methods for Cryptanalysis
    密码学SAT入门文献2——CDCL(Crypto)SATSolversforCryptanalysis  Abstract Algebraicsolvingofpolynomialsystemsandsatisfiabilityofproposi......
  • 网络系统管理Linux环境——7.ROUTERSRV之IPTABLES
    题目要求服务器RouterSrv上的工作任务6. IPTABLES添加必要的网络地址转换规则,使外部客户端能够访问到内部服务器上的dns、mail、web和ftp服务。INPUT、OUTPUT和FOREARD链......
  • pta python实验1-3
    7-1HelloWorld这是学习每种程序设计语言的第一个实例。‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬输出Hell......
  • SYNU PTA C++ 第三章实验题
    题目详细内容见PTA,仅提供答案参考。7-7冒泡1#include<iostream>2usingnamespacestd;34voidmerge(int*arr,intleft,intmid,intright)5{6......
  • 2022 年值得推荐的 Vue 库 ,富文本Tiptap
    https://blog.csdn.net/maxue20161025/article/details/127692983 https://github.com/Leecason/element-tiptap/blob/master/README_ZH.md  ---Tiptap  ......
  • 强大的iptables:解锁Linux网络安全的神器
    iptables是Linux系统中的防火墙管理工具,它的功能强大并且使用灵活,可用于网络防护、路由转发等功能应用。由于防火墙功能是基于Linux内核实现的,具有稳定和高效率的特点,因此常......
  • iptables的使用
    iptables的使用iptables介绍iptables是基于内核提供的netfilter框架实现的,网络协议栈是分层的,在tcpip网络模型里,tcp传输层下面的一层就是ip网络层,而netfilter就是工作在......
  • 使用iptabels将主机的所有流量转发至其他机器
    iptables是一个Linux内核中的包过滤工具,可以用来过滤、转发、修改、控制网络流量等。如果想要将主机的所有流量转发至其他机器,可以使用iptables进行配置。以下是具体步骤:......
  • 论文解读(ToAlign)《ToAlign: Task-oriented Alignment for Unsupervised Domain Adapta
    论文信息论文标题:ToAlign:Task-orientedAlignmentforUnsupervisedDomainAdaptation论文作者:GuoqiangWei,CuilingLan,WenjunZeng,ZhizhengZhang,ZhiboChen......