题解 | #二叉树的下一个结点#

二叉树的下一个结点

https://www.nowcoder.com/practice/9023a0c988684a53960365b889ceaf5e

/*
struct TreeLinkNode {
    int val;
    struct TreeLinkNode *left;
    struct TreeLinkNode *right;
    struct TreeLinkNode *next;
    TreeLinkNode(int x) :val(x), left(NULL), right(NULL), next(NULL) {
        
    }
};
*/


class Solution {
public:



TreeLinkNode* zxbianli(TreeLinkNode* pNode,TreeLinkNode* node)
{
    static TreeLinkNode* tree = nullptr;
    static int k=0;
    if (pNode)
    {
        if (pNode->left)
            zxbianli(pNode->left,node);
                        if(k)
            {
                tree=pNode;
                k=0;
            }
            cout<<'!'<<pNode->val;
        if (pNode==node)
            k=1;

        if (pNode->right)
            zxbianli(pNode->right,node);


    }
    return tree;



}






    TreeLinkNode* GetNext(TreeLinkNode* pNode) {
       

       static TreeLinkNode* head = nullptr;
       static TreeLinkNode *node=pNode;

        while(!head)
        {
            if(pNode->next)
            pNode=pNode->next;
            else head=pNode;
        }
        
        cout<<head->val<<'-'<<node->val;
        head=zxbianli(head,node);



        return head;

    }
};

一开始想复杂了,其实这道题只需要先找到根节点,然后在中序遍历就行了.

我一开始想的是怎么不找到根节点然后找下一个,但实际上找根节点很简单,复杂度低,是一个好方法.

全部评论

相关推荐

找工作勤劳小蜜蜂:自我描述部分太差,完全看不出想从事什么行业什么岗位,也看不出想在哪个地区发展,这样 会让HR很犹豫,从而把你简历否决掉。现在企业都很注重员工稳定性和专注性,特别对于热爱本行业的员工。 你实习的工作又太传统的it开发(老旧),这部分公司已经趋于被淘汰,新兴的互联网服务业,比如物流,电商,新传媒,游戏开发和传统的It开发有天然区别。不是说传统It开发不行,而是就业岗位太少,基本趋于饱和,很多老骨头还能坚持,不需要新血液。 工作区域(比如长三角,珠三角,成渝)等也是HR考虑的因素之一,也是要你有个坚定的决心。否则去几天,人跑了,HR会被用人单位骂死。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务