经验tips:

Recursion is the best friend of tree-related problems.

一是只要遇到字符串的子序列或配准问题首先考虑动态规划DP,二是只要遇到需要求出所有可能情况首先考虑用递归。

93 - restore IP address

注:

A。在return条件之前先判断valid的条件 1, max bits per partition[size() - startIndex <= (4 - parts) * 3] 2, min bit per partiton[1].否则在1111 的情况会重复输出level直接被push进result里。

B。recursive语句在for循环的if的判断语句里。

95 - unique binary search tree II

对于第i个node generate from 1~i - 1 给左子树 i+1~n右子树。

三层循环: 第i个node vector<TreeNode*> left left[j] right[k] 最里层循环new节点i 赋值i, i->left, i->right。然后push进vector tree里。最后return tree。

循环前加判断条件:当start > end 直接push NULL 然后return tree。

98. Validate Binary Search Tree

空树为真。

中序遍历,用lastnode记录并比较 如果大于当前node的val就return false。

判断条件:

A。if(!isValid(root ->left)) return false

B。if(!lastnode && lastnode->val>=root->val) return false  =====>   lastnode往下走 = root

C。return isValid(root -> right)

100. Same Tree

对每一个点的判断条件有三个:

A。同时为空 真

B。不同时为空 假

C。值不同 假

return isSame(p->left,q->left)&&isSame(p->right,q->right);

101. Symmetric Tree

判断方法与same tree 基本相同 最后recursive的时候左右树的左右子树对称比较。

104. Maximum Depth of Binary Tree

最底层:root == NULL时 return 0;

每一层会加一:return (l > r) ? l + 1 : r + 1;

int l = maxDepth(root -> left);

105. Construct Binary Tree from Preorder and Inorder Traversal

preorder第一个是root。在inorder中找root,然后分别generate左右子树。

typedef vector<int>::iterator Iter;

开始要判断是否为空树。

106. Construct Binary Tree from Inorder and Postorder Traversal

postorder最后一个是root。

108. Convert Sorted Array to Binary Search Tree

找median。先new root,左右分别recursive调用generate左右子树。

109. Convert Sorted List to Binary Search Tree

中序遍历。先generate左子树用变量存起来,再连接到root上,再root->right = generate(list,mid,end);

要先过一遍list求size。

110. Balanced Binary Tree

Maximum depth of binary tree的变形。

A。空树 return 0

B。不符合判断 return -1

C。依然return (l > r) ? l + 1:r+1。返回depth

主程序判断:只要返回值为-1就return false

111. Minimum Depth of Binary Tree

最底层:return条件:为空,返回0;为叶子节点,返回1。

与max depth不同的地方是return条件 +1换地方了。

最后return min(l,r)的时候别忘了加根。+ 1

112. Path Sum

return的是布尔值。

bool helper(TreeNode* root, int sum, int val){
  if(root == NULL) return false;
  val += root -> val;//语句顺序!!!!!
  if(val == sum && !root -> left && !root -> right){
    return true;
  }
  //val += root -> val;
  return helper(root -> left, sum, val)||helper(root -> right, sum, val);
}

113. Path Sum II

return为空。

每一层level pop的时候是在dfs完左右子树的时候。

result.push_back(level)的条件成立时 并不返回。原因是如果不在遍历完左右子树的时候返回,level里面的值会多出。

void dfs(TreeNode* root, int sum, vector<vector<int>>& result, vector<int>& level, int val){
  if(root == NULL) return;
  level.push_back(root -> val);//注意:对称结构在最外层!!!!!
  val += root -> val;
  if(val == sum && !root -> left && !root -> right){
    result.push_back(level);
    //return;
  }
  //while(root){
  else{
    if(root -> left){
      //level.push_back(root -> left -> val);
      dfs(root -> left, sum, result, level, val);
      //level.pop_back();
    }
    if(root -> right){
      //level.push_back(root -> right -> val);
      dfs(root -> right, sum, result, level, val);
      //level.pop_back();
    }
  }
  level.pop_back();
  val -= root -> val;
  return;////为啥在此处return啊!!!????

}

12/15/16

124. Binary Tree Maximum Path Sum

注:传的是节点的值 不是高度 最后return max(left, right) + root -> val;

但主程序返回的并不是recursion的值 而是全局变量ans

12/17/16

129. Sum Root to Leaf Numbers

Recursion. Similar as [LeetCode] Binary Tree Maximum Path Sum Solution, the difference here is only adding a track variable to sum all the paths.

void generate(TreeNode* root, int sum, int path){
  if(root == NULL) return;
  path = path * 10 + root -> val;
  if(root -> left == NULL && root -> right == NULL){
    sum += path;
    return;
  }
  generate(root -> left, sum, path);
  generate(root -> right, sum, path);
}

12/19/16

133. Clone Graph

注意:别忘了初始化table!!!!
table[newnode -> label] = newnode;

Recursive - leetcode [递归]的更多相关文章

  1. LeetCode 递归(Recursion) 培训专题 讲解文章翻译 (附链接)

     递归 - 时间复杂度 在本文中, 我们主要介绍如何分析递归算法程序中的时间复杂度.. 在一个递归程序中, 它的时间复杂度 O(T) 一般来说就是他总共递归调用的次数 (定义为 R) 以及每次调用时所 ...

  2. LeetCode递归解题模板

    39 40 78. Subsets https://leetcode.com/problems/subsets/description/ void subsets(vector<int>& ...

  3. React-router4 第七篇 Recursive Paths 递归路径

    https://reacttraining.com/react-router/web/example/recursive-paths import React from 'react' import ...

  4. LeetCode递归 -2(Recursion) 培训专题 讲解文章翻译 (附链接) (2019-04-09 15:50)

    递归 - 空间复杂度  在本文中, 我们将讨论如何分析递归算法的空间复杂度. 在计算递归算法的空间复杂度时,最需要考虑的两个部分就是: 递归相关空间 (recursion related space) ...

  5. LeetCode || 递归 / 回溯

    呜呜呜 递归好不想写qwq 求“所有情况”这种就递归 17. Letter Combinations of a Phone Number 题意:在九宫格上按数字,输出所有可能的字母组合 Input: ...

  6. [03] Recursive Function递归应用

    递归应用 1.理解 百科:一种计算过程,如果其中每一步都要用到前一步或前几步的结果,称为递归的: 理解:函数调用自己的过程,这类函数处理的事情具有重复性,处理此类实行可用while或者for,但结构上 ...

  7. Leetcode 递归题

    24. 两两交换链表中的节点 题目描述: 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表. 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例: 给定 1->2-&g ...

  8. [leetcode] 94. Binary Tree Inorder Traversal 二叉树的中序遍历

    题目大意 https://leetcode.com/problems/binary-tree-inorder-traversal/description/ 94. Binary Tree Inorde ...

  9. wget 递归下载整个网站

    wget -r -p -np -k http://xxx.com/xxx -r,  --recursive(递归)          specify recursive download.(指定递归下 ...

随机推荐

  1. 解决中文乱码( jsp表单提交中文时出现乱码)

    有三种方法: 1.建立一个filter中文解决乱码 2.Struts2在struts.xml中修改默认的编码设定 3.用Spring解决中文乱码 4.直接在jsp中修改解决 1.建立一个filter解 ...

  2. windows下配置PHP+Nginx+MySQL完整流程(转)

    对于在windows上的php+nginx的配置可能好多同学一次根本都配不正确,于我也是如此,为此我将我成功配置的过程细致的总结如下,希望能帮助搞PHP研究的同学 1.资源准备 MySQL:这个链接不 ...

  3. 查找算法---find运算,find_first_of的使用

    查找算法---find运算,find_first_of的使用 一.find运算 假设有一个int型的vector对象,名为vec,我们想知道其中是否包含某个特定值. 解决这个问题最简单的方法时使用标准 ...

  4. Android中ListView下拉刷新的实现

    ListView中的下拉刷新是非常常见的,也是经常使用的,看到有很多同学想要,那我就整理一下,供大家参考.那我就不解释,直接上代码了. 这里需要自己重写一下ListView,重写代码如下: packa ...

  5. C#中数组,ArrayList与List对象的区别

    在C#中,当我们想要存储一组对象的时候,就会想到用数组,ArrayList,List这三个对象了.那么这三者到底有什么样的区别呢? 我们先来了解一下数组,因为数组在C#中是最早出现的. 数组 数组有很 ...

  6. 异常分析:关于jsp页面使用jstl

    1.在jsp页面中使用如下代码加入jstl的支持 <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/c ...

  7. Android Apk获取包名和Activity名称

    一.使用aapt(Android Asset Packaging Tool)工具获取: 1.配置Android环境: a.添加build-tools/android路径到系统环境变量的中Path中,注 ...

  8. React入门实例

    前言 React 的核心思想是:封装组件,各个组件维护自己的状态和UI,当状态变更,自动重新渲染整个组件. 理解:react首先值得拍手称赞的是它所有的开发都基于一个组件(component),组件和 ...

  9. Dell-R730 【Pxe+dhcp+ftp+tftp+Kickstart+CentOs6.6】

    IP:10.104.0.101 [root@localhost network-scripts]# cat ifcfg-em1 [root@localhost network-scripts]# ip ...

  10. Jmeter之录制脚本

    目前,思路:先录制→再压测. [一]录制的准备: 第一种:直接的模板(¬_¬) [1]File→Templates [2]看见Select Template→Recording→create [3]好 ...