PHP 函数中如何使用递归实现广度优先搜索算法?

PHPz
发布: 2024-09-02 18:24:04
原创
464人浏览过

php中使用递归实现bfs算法:标记起始节点为已访问。入队该节点的所有相邻节点。从队列中取出下一个节点。递归调用bfs,直到队列为空。

PHP 函数中如何使用递归实现广度优先搜索算法?

在 PHP 函数中使用递归实现广度优先搜索算法

简介:
广度优先搜索 (BFS) 是一种图论算法,用于从源点出发遍历所有可达点。PHP 函数可以使用递归来实现 BFS。

实现:

立即学习PHP免费学习笔记(深入)”;

百度文心百中
百度文心百中

百度大模型语义搜索体验中心

百度文心百中 22
查看详情 百度文心百中
function bfs($node, $visited, &$queue)
{
    // 标记节点为已访问
    $visited[$node] = true;
    
    // 入队相邻节点
    foreach ($node->neighbors as $neighbor) {
        if (!$visited[$neighbor]) {
            $queue[] = $neighbor;
        }
    }
    
    // 从队列中取出下一个节点
    if (count($queue) > 0) {
        $next_node = array_shift($queue);
        bfs($next_node, $visited, $queue);
    }
}
登录后复制

实战案例:

假设我们有一个图,其节点由Node类表示,邻居存储在neighbors属性中。以下是如何使用 BFS 从源点 1 遍历图:

// 创建图
$n1 = new Node(1);
$n2 = new Node(2);
$n3 = new Node(3);
$n4 = new Node(4);
$n5 = new Node(5);

$n1->neighbors = [$n2, $n3];
$n2->neighbors = [$n4, $n5];
$n3->neighbors = [$n5];
$n4->neighbors = [];
$n5->neighbors = [];

// 初始化访问标记和队列
$visited = [];
$queue = [$n1];

// 执行 BFS
bfs($n1, $visited, $queue);

// 输出遍历顺序
foreach ($visited as $node => $visited) {
    echo "{$node} ";
}
登录后复制

输出:
1 2 3 4 5

以上就是PHP 函数中如何使用递归实现广度优先搜索算法?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号