Original link: leetcode-cn.com/problems/bi…

Answer:

  1. The first thing to do with recursion is to think about what to do if the current recursive function is running the NTH recursion.
  2. The first thing to consider is that, assuming that the last node of the iteration is null, we set the termination condition for the recursion.
  3. The next step is to traverse the binary tree, which requires a recursive function to continue through the left and right nodes.
  4. In this handover, the logic of the current node is processed, that is, the value of the current node is stored. As it is traversal in middle order, the storage time is traversal between left and right nodes.
/** * Definition for a binary tree node. * function TreeNode(val) { * this.val = val; * this.left = this.right = null; *} * /
// Recursively traverses the binary tree
function recursion(node, arr) {
  // If the node is empty, exit
  if(! node) {return;
  }

  // Iterate over the left node
  recursion(node.left, arr);
  // In order of traversal, that is, between traversal left and right child nodes, output the current node value
  arr.push(node.val);
  // Iterate over the right node
  recursion(node.right, arr);
}
/ * * *@param {TreeNode} root
 * @return {number[]}* /
var inorderTraversal = function (root) {
  let result = []; // Save the result
  // Recursively traverses the binary tree
  recursion(root, result);
  return result;
};
Copy the code