[LintCode] Binary Tree Paths 二叉树路径

简介:

Given a binary tree, return all root-to-leaf paths.
Example
Given the following binary tree:

   1
 /   \
2     3
 \
  5
All root-to-leaf paths are:
[
  "1->2->5",
  "1->3"
]
LeetCode上的原题,请参见我之前的博客Binary Tree Paths

解法一:

class Solution {
public:
    /**
     * @param root the root of the binary tree
     * @return all root-to-leaf paths
     */
    vector<string> binaryTreePaths(TreeNode* root) {
        vector<string> res;
        if (root) helper(root, "", res);
        return res;
    }
    void helper(TreeNode *node, string out, vector<string> &res) {
        out += to_string(node->val);
        if (!node->left && !node->right) {
            res.push_back(out);
        } else {
            if (node->left) helper(node->left, out + "->", res);
            if (node->right) helper(node->right, out + "->", res);
        }
    }
};

解法二:

class Solution {
public:
    /**
     * @param root the root of the binary tree
     * @return all root-to-leaf paths
     */
    vector<string> binaryTreePaths(TreeNode* root) {
        if (!root) return {};
        if (!root->left && !root->right) return {to_string(root->val)};
        vector<string> left = binaryTreePaths(root->left);
        vector<string> right = binaryTreePaths(root->right);
        left.insert(left.end(), right.begin(), right.end());
        for (auto &a : left) {
            a = to_string(root->val) + "->" + a;
        }
        return left;
    }
};

本文转自博客园Grandyang的博客,原文链接:二叉树路径[LintCode] Binary Tree Paths ,如需转载请自行联系原博主。

相关文章
|
机器学习/深度学习 开发框架 安全
移动应用开发的未来:跨平台框架与原生系统的融合
【4月更文挑战第8天】 在数字化时代,移动应用已成为日常生活不可或缺的一部分。随着技术的不断进步和用户需求的多样化,移动应用开发正面临前所未有的挑战与机遇。本文将探讨移动应用开发领域的最新趋势,特别是跨平台开发框架与原生系统之间的融合,以及这一趋势如何影响开发者、企业以及最终用户。通过分析当前市场上流行的开发工具和技术,我们将展望移动应用开发的未来发展,并讨论如何利用这些技术来提升用户体验和市场竞争力。
|
11天前
|
数据采集 人工智能 安全
|
6天前
|
机器学习/深度学习 人工智能 前端开发
构建AI智能体:七十、小树成林,聚沙成塔:随机森林与大模型的协同进化
随机森林是一种基于决策树的集成学习算法,通过构建多棵决策树并结合它们的预测结果来提高准确性和稳定性。其核心思想包括两个随机性:Bootstrap采样(每棵树使用不同的训练子集)和特征随机选择(每棵树分裂时只考虑部分特征)。这种方法能有效处理大规模高维数据,避免过拟合,并评估特征重要性。随机森林的超参数如树的数量、最大深度等可通过网格搜索优化。该算法兼具强大预测能力和工程化优势,是机器学习中的常用基础模型。
332 164
|
5天前
|
机器学习/深度学习 自然语言处理 机器人
阿里云百炼大模型赋能|打造企业级电话智能体与智能呼叫中心完整方案
畅信达基于阿里云百炼大模型推出MVB2000V5智能呼叫中心方案,融合LLM与MRCP+WebSocket技术,实现语音识别率超95%、低延迟交互。通过电话智能体与座席助手协同,自动化处理80%咨询,降本增效显著,适配金融、电商、医疗等多行业场景。
337 155
|
6天前
|
编解码 人工智能 自然语言处理
⚽阿里云百炼通义万相 2.6 视频生成玩法手册
通义万相Wan 2.6是全球首个支持角色扮演的AI视频生成模型,可基于参考视频形象与音色生成多角色合拍、多镜头叙事的15秒长视频,实现声画同步、智能分镜,适用于影视创作、营销展示等场景。
414 4