/**
* @param {TreeNode} root
* @return {number}
*/
var findBottomLeftValue = function(root) {
// 层序遍历
// 每一层取左端点的数值
// const res = [];
const levelOrder = (node,level,position)=>{
if(!node){
return;
}else{
// res.push({
// level,
// val:node.val??0,
// position
// });
}
if(node.left){
levelOrder(node.left,level+1,'left')
}
if(node.right){
levelOrder(node.right,level+1,'right')
}
if(level+1>curLevel){
curLevel = level+1;
curVal = node.val;
}
}
let curLevel = 0,curVal=0;
levelOrder(root,0,'left');
return curVal;
// res.sort((a,b)=>a.level-b.level)
// for(let i=res.length-1;i>=0;i--){
// if(res[i].position == 'left'){
// return res[i].val;
// }
// }
};
执行结果:通过
执行用时:60 ms, 在所有 JavaScript 提交中击败了96.15%的用户
内存消耗:44.7 MB, 在所有 JavaScript 提交中击败了95.36%的用户
通过测试用例:76 / 76
var findBottomLeftValue = function(root){
const dfs = (root,height)=>{
if(!root){
return;
}
height++;
dfs(root.left,height);
dfs(root.right,height);
if(height>curHeight){
curHeight = height;
curVal = root.val;
}
}
let curHeight = 0,curVal = 0;
dfs(root,0);
return curVal;
}
执行结果:通过
执行用时:68 ms, 在所有 JavaScript 提交中击败了74.47%的用户
内存消耗:44.9 MB, 在所有 JavaScript 提交中击败了79.67%的用户
通过测试用例:76 / 76
var findBottomLeftValue = function(root){
let res = 0;
const queue = [root];
while(queue.length){
const p = queue.shift();
if(p.right){
queue.push(p.right);
}
if(p.left){
queue.push(p.left);
}
res = p.val;
}
return res;
}
执行结果:通过
执行用时:68 ms, 在所有 JavaScript 提交中击败了74.47%的用户
内存消耗:44.7 MB, 在所有 JavaScript 提交中击败了93.87%的用户
通过测试用例:76 / 76