码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • L2-031 深入虎穴


    著名的王牌间谍 007 需要执行一次任务,获取敌方的机密情报。已知情报藏在一个地下迷宫里,迷宫只有一个入口,里面有很多条通路,每条路通向一扇门。每一扇门背后或者是一个房间,或者又有很多条路,同样是每条路通向一扇门…… 他的手里有一张表格,是其他间谍帮他收集到的情报,他们记下了每扇门的编号,以及这扇门背后的每一条通路所到达的门的编号。007 发现不存在两条路通向同一扇门。

    内线告诉他,情报就藏在迷宫的最深处。但是这个迷宫太大了,他需要你的帮助 —— 请编程帮他找出距离入口最远的那扇门。

    输入格式:

    输入首先在一行中给出正整数 N(<105),是门的数量。最后 N 行,第 i 行(1≤i≤N)按以下格式描述编号为 i 的那扇门背后能通向的门:

    K D[1] D[2] ... D[K]
    

    其中 K 是通道的数量,其后是每扇门的编号。

    输出格式:

    在一行中输出距离入口最远的那扇门的编号。题目保证这样的结果是唯一的。

    输入样例:

    1. 13
    2. 3 2 3 4
    3. 2 5 6
    4. 1 7
    5. 1 8
    6. 1 9
    7. 0
    8. 2 11 10
    9. 1 13
    10. 0
    11. 0
    12. 1 12
    13. 0
    14. 0

    输出样例:

    12
    1. #include <iostream>
    2. #include <vector>
    3. #include <set>
    4. #include <map>
    5. #include <string>
    6. #include <algorithm>
    7. #include <cstdlib>
    8. using namespace std;
    9. #define M 100000
    10. vector<int> arr[M + 5];
    11. int ans = 0, deep = 0;
    12. int n;
    13. set<int> s;
    14. void dfs(int i, int d) {
    15. if (d > deep) {
    16. deep = d;
    17. ans = i;
    18. }
    19. if (arr[i].empty()) return;
    20. for (auto x : arr[i]) {
    21. dfs(x, d + 1);
    22. }
    23. return;
    24. }
    25. int main() {
    26. cin >> n;
    27. for (int i = 1, a; i <= n; i++) {
    28. cin >> a;
    29. for (int j = 0, b; j < a; j++) {
    30. cin >> b;
    31. arr[i].push_back(b);
    32. s.insert(b);
    33. }
    34. }
    35. int root;
    36. for (int i = 1; i <= n; i++) {
    37. if (!s.count(i)) {
    38. root = i;
    39. break;
    40. }
    41. }
    42. dfs(root, 1);
    43. cout << ans;
    44. return 0;
    45. }

     

  • 相关阅读:
    浏览器模块化详解
    改进YOLOv7系列:25.YOLOv7 加入RepVGG模型结构,重参数化 极简架构
    行业追踪,2023-10-26
    STM32开发_利用SPI协议读写SD卡、介绍SD卡SPI时序
    是时候来点现代c++了 c++17重要新特性解析
    无处不在的智慧:嵌入式系统引领智能生活
    百度发布Q3财报:AI原生应用驱动业绩增长 公司股价应声涨超5%
    Redis事物和锁机制
    如何写出匹配Java方法注释的正则表达式
    web初识
  • 原文地址:https://blog.csdn.net/Mz_yuner/article/details/133916762
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号