栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

广度优先(BFS)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

广度优先(BFS)

1 广度优先简介

常常使用队列来配合解决。

2 力扣题目 2.1 二叉树的最小深度

111. 二叉树的最小深度

迭代版本:

class Solution {
public:
    int minDepth(TreeNode* root) {
		if (!root)
		{
			return 0;
		}

		queue q;
		q.push(root);
		//root本身就是一层,所以初始化为1
		int minDep = 1;
		while (!q.empty())
		{
			int sz = q.size();
			//将当前队列中的所有节点向四周扩散
			for (int i = 0;i < sz; ++i)
			{
				TreeNode *cur = q.front();
				q.pop();
				//判断是否到达终点
				if (!cur->left && !cur->right)
				{
					return minDep;
				}

				//将cur相邻的节点加入队列
				if (cur->left)
				{
					q.push(cur->left);
				}

				if (cur->right)
				{
					q.push(cur->right);
				}
			}
			//这里增加步数
			++minDep;
		}

		return minDep;    
    }
};

递归版本:

class Solution {
public:
    int minDepth(TreeNode* root) {
        if (!root)
        {
            return 0;
        }

        if (!root->left)
        {
            return 1 + minDepth(root->right);
        }
        else if (!root->right)
        {
            return 1 + minDepth(root->left);
        }
        else
        {
            return 1 + std::min(minDepth(root->left), minDepth(root->right));
        }       
    }
};

2.2

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/698563.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号