zoukankan      html  css  js  c++  java
  • Sum Root to Leaf Numbers [LeetCode]

    Problem description: http://oj.leetcode.com/problems/sum-root-to-leaf-numbers/

    Basic idea: To store the num vector in every node of tree by starting from leaf, the go up util to root.

     1 class Solution {
     2 public:
     3     vector<vector<int>> subNumbers(TreeNode *root) {
     4         vector<vector<int>> sums;
     5         if(root == NULL)
     6             return sums;
     7         
     8         if(root->left == NULL && root->right == NULL){
     9             vector<int> seq;
    10             seq.push_back(root->val);
    11             sums.push_back(seq);
    12             return sums;
    13         }
    14             
    15         vector<vector<int>> left_sums = subNumbers(root -> left);
    16         for(auto item: left_sums) {
    17             item.insert(item.begin(), root->val);
    18             sums.push_back(item);
    19         }
    20         
    21         vector<vector<int>> right_sums = subNumbers(root -> right);
    22         for(auto item: right_sums) {
    23             item.insert(item.begin(), root->val);
    24             sums.push_back(item);
    25         }
    26         return sums;
    27     }
    28     
    29     int pow10(int n) {
    30         int ret = 1;
    31         for(int i = 0; i < n; i++)
    32             ret = ret * 10;
    33             
    34         return ret;
    35     }
    36     
    37     int sumNumbers(TreeNode *root) {
    38         // Note: The Solution object is instantiated only once and is reused by each test case.
    39         int sum = 0;
    40         vector<vector<int>> sums = subNumbers(root);
    41         for(auto v : sums){
    42             int tmp_sum = 0;
    43             for(int i = v.size() - 1; i >= 0; i -- ) {
    44                 tmp_sum += v[i] * pow10(v.size() - 1 - i);
    45             }
    46             sum += tmp_sum;
    47         }
    48         return sum;
    49     }
    50 };
  • 相关阅读:
    python基础—函数装饰器
    python基础—函数嵌套与闭包
    Python之三级菜单
    Python之运算符
    Python之字典
    Python之购物车
    Python之列表
    Python之布尔
    Python之“Hello World”
    Python之递归函数
  • 原文地址:https://www.cnblogs.com/guyufei/p/3390489.html
Copyright © 2011-2022 走看看