leetcode 114 二叉树变链表

O(1)空间解法:把右子树挂到左子树的最右节点

这个也有点贪心在,需要有点记忆,因为访问顺序是中 -> 左子树 -> 右子树,而左子树的最后一个节点是最右边那个,所以我们把右子树挂上去,这样循环往复,就可以得到链表。

为什么每个节点只能访问一次?

第一次遍历完后,只有下一次主循环才会遇到。

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    void flatten(TreeNode* root) {
        TreeNode *curr = root;
        while(curr)
        {
            if(curr->left)
            {
                TreeNode *last = curr->left;
                while(last->right)last = last->right;

                last->right = curr->right;
                curr->right = curr->left;
                curr->left = nullptr;
            }

            curr = curr->right;
        }

    }
};
相关推荐
cpp_250110 分钟前
P1024 [NOIP 2001 提高组] 一元三次方程求解
数据结构·c++·算法·题解·二分答案·洛谷·csp
田梓燊7 小时前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎7 小时前
算法札记——4.27
算法
数据牧羊人的成长笔记8 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理8 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
d111111111d11 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
Jiangxl~13 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢13 小时前
wolfram详解山峦算法
前端·算法
counting money13 小时前
prim算法最小生成树(java)
算法
澈20713 小时前
C++面向对象:类与对象核心解析
c++·算法