二叉树后序遍历反汇编的问题?

void lastorder(struct Node* root)   //后序遍历
{
    
    if (root != NULL)
    {
        lastorder(root->LChild);//直接往左子树边走  
        lastorder(root->RChild);//直接往右子树边走   反汇编中为什么递归函数一直调用右子树
        printf("%c", root->data);//数据根部   
    }
}

img

img


麻烦说下原理吧,不要再复制一些人家的文章发来了。
为什么在反汇编中,比如这个后序遍历, 为什么递归循环一直在遍历右子树呢?还有左子树啊为什么不使用呢?虽然调用右子树递归的时候也调用了左子树,但是为什么递归的时候只走右子树呢?是什么原理呢?

怎么可能一直是右子树。开始就一直找左子树,一直找到没有左子树的节点,然后找这个节点的右子数,再找这个右子树的左子树。直到找到某个节点时叶子结点才开始输出节点数据。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632