搜索
首页后端开发php教程。找到最终的安全状态
。找到最终的安全状态Jan 25, 2025 am 06:04 AM

802。查找最终的安全状态

难度:中等

>主题:深度优先搜索,广度优先搜索,图形,拓扑排序

有一个定向的n个节点图,每个节点从0到n -1标记。该图由a 0- indexed 2D integer阵列图表示,其中图[i]是一个整数阵列与节点I相邻的节点的源,这意味着从节点i到图中的每个节点有一个边缘[i]。

。 如果没有传出边缘,则一个节点为

终端节点。节点是a安全节点如果从该节点开始的每个可能的路径都会导致>终端节点(或另一个安全节点)。

返回

一个包含图形的所有安全节点的数组。答案应以上升顺序排序。 >>示例1:

。找到最终的安全状态>输入:

graph = [[1,2],[2,3],[5],[0],[5],[5],[],[],[]]
  • >输出: [2,4,5,6]
  • >说明:给定的图如上所示。 节点5和6是终端节点,因为其中任何一个都没有外向。 从节点2、4、5和6开始的每条路径都导致节点5或6。
  • >
  • >示例2:
  • 输入:

    graph = [[1,2,3,4],[1,2],[3,4],[0,4],[0,4],[]] >输出:

    [4]
    • >说明:只有节点4是一个终端节点,从节点4开始的每个路径都会导致节点4。
    • >
    • >约束:
    • > n == graph.length
    1< = n< = 10 4 > 0< = graph [i] .length< = n
    • 0< = graph [i] [j]< = n -1
    • 图[i]以严格增加的顺序进行排序。 该图可能包含自宽。
    • >
    • 图中的边数将在[1,4 * 10
    • 4
    • ]范围内。
    • 解决方案:
    • 我们需要识别图表中的所有安全节点。这涉及检查是否从给定节点开始,每个路径最终都到达终端节点或其他安全节点。该解决方案使用深度优先搜索(DFS)来检测周期并将节点分类为安全或不安全。

      关键见解:

      1. >终端节点:一个没有传出边缘的节点是终端节点。
      2. >安全节点:一个节点是安全的,如果从该节点开始,所有路径最终都会导致终端节点或其他安全节点。
      3. 循环检测
      4. :如果节点是周期的一部分,则不是一个安全的节点,因为从其开始的路径不会导致终端节点。 方法:

      我们使用DFS探索每个节点并确定它是否是周期的一部分。循环或导致周期的一部分的节点标记不安全。 最终导致终端节点或其他安全节点的节点被标记为安全。

      >
      • 我们使用一个访问的数组,带有三个状态:
      • 0:尚未访问该节点。

      1:该节点当前正在访问(即,在递归堆栈中)。

      >
        2:该节点已完全处理并且是安全的。
      • 步骤:
      • >为每个节点执行DFS。

      使用访问的状态标记安全/不安全的节点。收集所有安全的节点。
      1. >让我们在PHP中实现此解决方案: 802。查找最终的安全状态
      2. 解释:


      dfs函数

      <?php /**
       * @param Integer[][] $graph
       * @return Integer[]
       */
      function eventualSafeNodes($graph) {
          ...
          ...
          ...
          /**
           * go to ./solution.php
           */
      }
      
      /**
       * DFS helper function
       *
       * @param $node
       * @param $graph
       * @param $visited
       * @return int|mixed
       */
      function dfs($node, $graph, &$visited) {
          ...
          ...
          ...
          /**
           * go to ./solution.php
           */
      }
      
      // Example usage:
      $graph1 = [[1,2],[2,3],[5],[0],[5],[],[]];
      $graph2 = [[1,2,3,4],[1,2],[3,4],[0,4],[]];
      
      print_r(eventualSafeNodes($graph1)) . "\n"; // Output: [2,4,5,6]
      print_r(eventualSafeNodes($graph2)) . "\n"; // Output: [4]
      ?>
      

      > DFS函数在节点上执行深度优先搜索,在开始时将其标记为“访问”(1),并且“安全”(2)当其所有邻居都安全时(2)
        如果其任何邻居都导致一个周期(由DFS($ neighbor)== 1表示),则该节点标记为不安全(1)。
      1. 如果所有邻居都导致终端节点或安全节点,则标记为安全(2)。

          主函数
        • 我们迭代所有节点,并使用DFS检查每个节点是否安全。
        • >
        • >所有安全节点均收集在$ Safenodes数组中并返回。>
      2. 示例演练: 示例1:

        • 在此示例中,节点5和6是终端节点(无外部边缘)。
        • >节点4导致节点5,因此也是安全的。>节点2导致节点5,因此它是安全的。>

      输出:

      $graph = [[1,2],[2,3],[5],[0],[5],[],[]];
      print_r(eventualSafeNodes($graph));
      
        示例2:
      • 在此示例中,只有节点4是终端节点,从节点4开始的所有路径引向节点4。>
      • 所有其他节点最终导致周期或不安全的节点。
      • 输出:

      <?php /**
       * @param Integer[][] $graph
       * @return Integer[]
       */
      function eventualSafeNodes($graph) {
          ...
          ...
          ...
          /**
           * go to ./solution.php
           */
      }
      
      /**
       * DFS helper function
       *
       * @param $node
       * @param $graph
       * @param $visited
       * @return int|mixed
       */
      function dfs($node, $graph, &$visited) {
          ...
          ...
          ...
          /**
           * go to ./solution.php
           */
      }
      
      // Example usage:
      $graph1 = [[1,2],[2,3],[5],[0],[5],[],[]];
      $graph2 = [[1,2,3,4],[1,2],[3,4],[0,4],[]];
      
      print_r(eventualSafeNodes($graph1)) . "\n"; // Output: [2,4,5,6]
      print_r(eventualSafeNodes($graph2)) . "\n"; // Output: [4]
      ?>
      

      时间和空间复杂度:

      • 时间复杂度O(n e),其中n是节点数,e 是边数。我们访问每个节点一次并处理每条边一次。
      • 空间复杂度O(n) 用于访问的数组和递归堆栈。

      该解决方案使用 DFS 有效地确定安全节点,确保满足问题约束。

      联系链接

      如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

      如果您想要更多类似的有用内容,请随时关注我:

      • 领英
      • GitHub

    以上是。找到最终的安全状态的详细内容。更多信息请关注PHP中文网其他相关文章!

    声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    在Laravel中使用Flash会话数据在Laravel中使用Flash会话数据Mar 12, 2025 pm 05:08 PM

    Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

    php中的卷曲:如何在REST API中使用PHP卷曲扩展php中的卷曲:如何在REST API中使用PHP卷曲扩展Mar 14, 2025 am 11:42 AM

    PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

    简化的HTTP响应在Laravel测试中模拟了简化的HTTP响应在Laravel测试中模拟了Mar 12, 2025 pm 05:09 PM

    Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

    在Codecanyon上的12个最佳PHP聊天脚本在Codecanyon上的12个最佳PHP聊天脚本Mar 13, 2025 pm 12:08 PM

    您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

    PHP记录:PHP日志分析的最佳实践PHP记录:PHP日志分析的最佳实践Mar 10, 2025 pm 02:32 PM

    PHP日志记录对于监视和调试Web应用程序以及捕获关键事件,错误和运行时行为至关重要。它为系统性能提供了宝贵的见解,有助于识别问题并支持更快的故障排除

    解释PHP中晚期静态结合的概念。解释PHP中晚期静态结合的概念。Mar 21, 2025 pm 01:33 PM

    文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

    自定义/扩展框架:如何添加自定义功能。自定义/扩展框架:如何添加自定义功能。Mar 28, 2025 pm 05:12 PM

    本文讨论了将自定义功能添加到框架上,专注于理解体系结构,识别扩展点以及集成和调试的最佳实践。

    See all articles

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    AI Hentai Generator

    AI Hentai Generator

    免费生成ai无尽的。

    热门文章

    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    3 周前By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.最佳图形设置
    3 周前By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.如果您听不到任何人,如何修复音频
    3 周前By尊渡假赌尊渡假赌尊渡假赌

    热工具

    Atom编辑器mac版下载

    Atom编辑器mac版下载

    最流行的的开源编辑器

    Dreamweaver Mac版

    Dreamweaver Mac版

    视觉化网页开发工具

    安全考试浏览器

    安全考试浏览器

    Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

    mPDF

    mPDF

    mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),