手记

【学习打卡】第14天 数据结构之“树”

课程名称:JavaScript版数据结构与算法
课程章节:第8章 数据结构之“树”
主讲老师:lewis

课程内容:

今天学习的内容包括:
8-7 LeetCode:102. 二叉树的层序遍历——通过广度优先遍历,记录同一层级节点并返回。
8-8 LeetCode:94. 二叉树的中序遍历——中序遍历为左根右,把对应遍历记录返回。
8-9 LeetCode:112. 路径总和——通过深度度优先遍历计算每条路径值的和是否满足targetSum。

课程收获:

二叉树的层序遍历

1、基于广度优先遍历实现二叉树的层序遍历
2、本题使用了三种解法

/**
 * @param {TreeNode} root
 * @return {number[][]}
 */
var levelOrder = function(root) {
    if(!root) return []
    // -------------------1------------------
    // let res = []
    // let btf = (p,l) => {
    //     if(res[l]){
    //         res[l].push(p.val)
    //     }else{
    //         res.push([p.val])
    //     }
    //     if(p.left) btf(p.left,l+1)
    //     if(p.right) btf(p.right,l+1)
    // }
    // btf(root,0)
    // -------------------1------------------
    // -------------------2------------------
    // let res = []
    // let p = [[root,0]]
    // while(p.length){
    //     let [n,l] = p.shift()
    //     if(res[l]){
    //         res[l].push(n.val)
    //     }else{
    //         res.push([n.val])
    //     }
    //     if(n.left) p.push([n.left,l+1])
    //     if(n.right) p.push([n.right,l+1])
    // }
    // -------------------2------------------
    // -------------------3------------------
    let res = []
    let p = [root]
    while(p.length){
        let len = p.length
        res.push([])
        while(len--) {
            let n = p.shift()
            res[res.length - 1].push(n.val)
            if(n.left) p.push(n.left)
            if(n.right) p.push(n.right)
        }
    }
    // -------------------3------------------
    return res
};

二叉树的中序遍历

1、中序遍历的特点为左中右遍历模式
2、将遍历以数据返回
3、本题使用两种解题方法

/**
 * @param {TreeNode} root
 * @return {number[]}
 */
var inorderTraversal = function(root) {
    // let res = []
    // const rec = (n) => {
    //     if(!n) return
    //     rec(n.left)
    //     res.push(n.val)
    //     rec(n.right)
    // }
    // rec(root)
    let res = []
    let stack = []
    let p = root
    while(stack.length || p){
        while(p){
            stack.push(p)
            p = p.left
        }
        const n = stack.pop()
        res.push(n.val)
        p = n.right
    }
    return res
};

路径总和

1、通过深度度优先遍历计算每条路径值的和是否满足targetSum
2、如果满足返回true否则返回false
3、本题采用两种解题方法

/**
 * @param {TreeNode} root
 * @param {number} targetSum
 * @return {boolean}
 */
var hasPathSum = function(root, targetSum) {
  if(!root) return false
  // let stack = [[root, 0]]
  // while(stack.length){
  //   let [p,l] = stack.shift()
  //   if(!p.left && !p.right && l+p.val === targetSum) return true
  //   if(p.left) stack.push([p.left, l+p.val])
  //   if(p.right) stack.push([p.right, l+p.val])
  // }
  // return false
  let res = false
  const dfs = (p,l) => {
    if(!p.left && !p.right && l+p.val === targetSum) res = true
    if(p.left) dfs(p.left, l+p.val)
    if(p.right) dfs(p.right, l+p.val)
  }
  dfs(root, 0)
  return res
};

今天学习的这三道算法题,都是先自己思考然后尝试着写,自己也写出来了一点东西,再结合老师所讲的内容,感觉收获还是很大的,感觉自己还是能够学得会,写得出,能思考,能解决问题的,对自己说一句,加油😀~

坚持打卡,坚持学习!明天见💪~

​​​​

0人推荐
随时随地看视频
慕课网APP