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 };

 

posted @ 2013-10-27 07:35  假日笛声  阅读(276)  评论(0编辑  收藏  举报