【一天一道LeetCode】#257. Binary Tree Paths

来源:互联网 发布:vb format函数 编辑:程序博客网 时间:2024/05/18 00:28

一天一道LeetCode

本系列文章已全部上传至我的github,地址:ZeeCoder‘s Github
欢迎大家关注我的新浪微博,我的新浪微博
欢迎转载,转载请注明出处

(一)题目

Given a binary tree, return all root-to-leaf paths.
For example, given the following binary tree:
1
/ \
2 3
\
5
All root-to-leaf paths are:
[“1->2->5”, “1->3”]

(二)解题

题目大意:给定一个二叉树,输出所有根节点到叶子节点的路径。
解题思路:采用深度优先搜索,碰到叶子节点就输出该条路径。
需要注意以下几点(也是我在解题过程中犯的错误):

  1. 需要考虑节点值为负数的情况,要转成string
  2. 要按照题目给定的格式来输出。
    下面看具体代码:
/** * Definition for a binary tree node. * struct TreeNode { *     int val; *     TreeNode *left; *     TreeNode *right; *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */class Solution {public:    vector<string> binaryTreePaths(TreeNode* root) {        vector<string> ret;        string tmp;        if(root!=NULL) dfsTreePaths(root,ret,tmp);        return ret;    }    void dfsTreePaths(TreeNode* root,vector<string>& ret, string tmp)    {        if(root->left == NULL&& root->right==NULL) {//如果为叶子节点就输出            char temp[10];            sprintf(temp, "%d", root->val);//将整数转换成string            tmp += string(temp);            ret.push_back(tmp);            return;        }        char temp[10];        sprintf(temp, "%d", root->val);//将整数转换成string        tmp += string(temp);        tmp +="->";        if(root->left !=NULL) dfsTreePaths(root->left,ret,tmp);//继续搜索左子树        if(root->right !=NULL) dfsTreePaths(root->right,ret,tmp);//继续搜索右子树    }};
0 0
原创粉丝点击