leetcode每日一题42

107.二叉树的层序遍历II

就层序遍历后reverse一下

cpp 复制代码
class Solution {
public:
    vector<vector<int>> levelOrderBottom(TreeNode* root) {
        queue<TreeNode*> que;
        if(root!=nullptr)
            que.push(root);
        vector<vector<int>> result;
        while(!que.empty()){
            int size=que.size();
            vector<int> vec;
            for(int i=0;i<size;i++)
            {
                TreeNode* node=que.front();
                que.pop();
                vec.push_back(node->val);
                if(node->left) que.push(node->left);
                if(node->right) que.push(node->right);
            }
            result.push_back(vec);
        }
        reverse(result.begin(),result.end());
        return result;
    }
};

109. 有序链表转换二叉搜索树

先用快慢指针找中点,再递归构造二叉搜索树

类似二分

cpp 复制代码
class Solution {
public:
    ListNode* midNode(ListNode* left,ListNode* right){
        ListNode *fast,*slow;
        fast=left;
        slow=left;
        while(fast!=right&&fast->next!=right)
        {
            fast=fast->next;
            fast=fast->next;
            slow=slow->next;
        }
        return slow;
    }
    TreeNode* buildTree(ListNode* left,ListNode* right){
        if(left==right)
            return nullptr;
        ListNode* mid=midNode(left,right);
        TreeNode* root=new TreeNode(mid->val);
        root->left=buildTree(left,mid);
        root->right=buildTree(mid->next,right);
        return root;
        
    }
    TreeNode* sortedListToBST(ListNode* head) {
        
        return buildTree(head,nullptr);//左闭右开区间
    }
};

113. 路径总和 II

112是返回有没有总和为给定值的路径,这道题是返回所有总和为给定值的路径

因此要遍历整个树,找到所有路径,且不用处理递归返回值,所以递归函数不要返回值!

  1. 确定递归函数的参数和返回类型
    需要二叉树的根节点,还需要一个计数器,这个计数器用来计算二叉树的一条边之和是否正好是目标和,计数器为int型
cpp 复制代码
void traversal(TreeNode* cur, int count) 
  1. 确定终止条件
    让计数器count初始为目标和,然后每次减去遍历路径节点上的数值。
    如果最后count == 0,同时到了叶子节点的话,说明找到了目标和。
    如果遍历到了叶子节点,count不为0,就是没找到。
cpp 复制代码
if(count==0&&!cur->left&&!cur->right){
	result.push_back(path);
	return;
}
else if (!cur->left && !cur->right)
	return;
  1. 确定单层递归的逻辑
    如果子节点不为空,加入path,count减去子节点值,递归,递归结束后,回溯,count加回来,去除path中的子节点
cpp 复制代码
if(cur->left)
{
    path.push_back(cur->left->val);
    count-=cur->left->val;
    traversal(cur->left,count);
    count+=cur->left->val;
    path.pop_back();
}
if(cur->right)
{
    path.push_back(cur->right->val);
    count-=cur->right->val;
    traversal(cur->right,count);
    count+=cur->right->val;
    path.pop_back();
}

整体代码

cpp 复制代码
class Solution {
public:
    vector<int> path;
    vector<vector<int>> result;
    void traversal(TreeNode* cur, int count) 
    {
        if(count==0&&!cur->left&&!cur->right){
            result.push_back(path);
            return;
        }
        else if (!cur->left && !cur->right)
            return;
        if(cur->left)
        {
            path.push_back(cur->left->val);
            count-=cur->left->val;
            traversal(cur->left,count);
            count+=cur->left->val;
            path.pop_back();
        }
        if(cur->right)
        {
            path.push_back(cur->right->val);
            count-=cur->right->val;
            traversal(cur->right,count);
            count+=cur->right->val;
            path.pop_back();
        }
        return;
    }
    vector<vector<int>> pathSum(TreeNode* root, int targetSum) {
        result.clear();
        path.clear();
        if (root == NULL) return result;
        path.push_back(root->val); // 把根节点放进路径
        traversal(root, targetSum - root->val);
        return result;
    }
};

114. 二叉树展开为链表

这不就是前序遍历

其实要做的就是按前序序列创建一个树,每个节点只有右子树

相关推荐
yuuki23323315 分钟前
【C++】类和对象(上)
c++·后端·算法
dangdang___go22 分钟前
动态内存管理||malloc和free.realloc和calloc
c语言·开发语言·算法·动态内存管理
稚辉君.MCA_P8_Java22 分钟前
Gemini永久会员 快速排序(Quick Sort) 基于分治思想的高效排序算法
java·linux·数据结构·spring·排序算法
数字化脑洞实验室35 分钟前
智能决策与决策优化:从算法到产业的演进逻辑
算法
cpp_250136 分钟前
P5412 [YNOI2019] 排队
数据结构·c++·算法·题解·洛谷
kingmax542120081 小时前
图论核心算法(C++):包括存储结构、核心思路、速记口诀以及学习方法, 一站式上机考试学习【附PKU百练,相关练习题单】
c++·算法·图论·信奥赛·上机考试·百练·pku
罗湖老棍子1 小时前
【例9.15】潜水员(信息学奥赛一本通- P1271)
c++·算法·动态规划·二维费用背包
_OP_CHEN1 小时前
算法基础篇:(二十一)数据结构之单调栈:从原理到实战,玩转高效解题
数据结构·算法·蓝桥杯·单调栈·算法竞赛·acm/icpc
代码游侠2 小时前
学习笔记——数据结构学习
linux·开发语言·数据结构·笔记·学习
q***51892 小时前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构