首页 > 其他分享 >144-12

144-12

时间:2023-10-12 21:14:21浏览次数:34  
标签:144 12 return top 结点 TreeNode data Stack

在二叉树中查找值为x的结点,找出该结点所有的祖宗结点,值为x的结点个数不多于1个

利用二叉树的后序非递归遍历,在Pop函数后判断是否结点值是否等于x,若等于,栈中全是x的祖宗结点,依次弹出

#include <stdio.h>
#include <stdlib.h>

#define MaxSize 100

typedef struct node{
    int data;
    struct node *lchild,*rchild;
}TreeNode,*Tree;

typedef TreeNode* Elem;

typedef struct{
    Elem data[MaxSize];
    int top;
}Stack;

void InitStack(Stack &S)
{
    S.top=-1;
}

bool isEmpty(Stack S)
{
    if(S.top==-1)
        return true;
    else
        return false;
}

bool isFull(Stack S)
{
    if(S.top==MaxSize-1)
        return true;
    else
        return false;
}

bool Push(Stack &S,Elem p)
{
    if(isFull(S))
        return false;
    S.data[++S.top]=p;
    return true;
}

bool Pop(Stack &S,Elem &p)
{
    if(isEmpty(S))
        return false;
    p=S.data[S.top--];
    return true;
}

bool GetTop(Stack S,Elem &p)
{
    if(isEmpty(S))
        return false;
    p=S.data[S.top];
    return true;
}

void CreateTree(Tree &T)
{
    int x;
    scanf("%d",&x);
    if(x==-1)
    {
        T=NULL;
        return;
    }
    else
    {
        T=(TreeNode*)malloc(sizeof(TreeNode));
        T->data=x;
        printf("输入%d的左结点:",x);
        CreateTree(T->lchild);
        printf("输入%d的右结点:",x);
        CreateTree(T->rchild);
    }
}

void Select(Tree T,int x)
{
    Stack S;
    InitStack(S);
    TreeNode *p=T;
    TreeNode *r=NULL;
    while(p || !isEmpty(S))
    {            
        if(p)
        {
            Push(S,p);
            p=p->lchild;
        }
        else
        {
            GetTop(S,p);
            if(p->rchild&&p->rchild!=r)
                p=p->rchild;
            else
            {
                Pop(S,p);
                if(p->data==x)
                {
                    printf("%d的祖宗结点是:",x);
                    while(!isEmpty(S))
                    {
                        Pop(S,p);
                        printf("%d  ",p->data);
                    }
                    return;    
                }    
                r=p;
                p=NULL;
            }
        }
    }
    printf("树T中不存在值等于%d的结点",x);
}

int main()
{
    Tree T;
    CreateTree(T);
    Select(T,0);
    return 0;
}

 

标签:144,12,return,top,结点,TreeNode,data,Stack
From: https://www.cnblogs.com/simpleset/p/17760554.html

相关文章

  • 2023-10-12 闲话
    昨天把所有博客全用markdown存到本地了。今天打算全转成pdf放到github上,但是人工实现工作量有点大。目前的想法是把所有图片换一个地方存一下。因为我们都不知道今年年底,我们热爱的、坚守的博客园命运会是什么样的。二十多年了。早上重新咀嚼了一下杨卓凡的话,感觉他说的还......
  • 10.12日
    一、上午学了跆拳道,侧踢,还有实战腿法。然后学了统一语言的对象图还有类图,抽象的不行,介绍了包图,不明白这个有什么用。二、下午学了数据结构,树的一点知识,树的深度。离散数学,等价关系和等价类。三、写了离散数学的作业,还有数据结构的部分作业。......
  • 2023.10.12
    大抵是没有挂分。简单题+博弈+图论+树论,典。xor一个\(n\timesn\)的空矩阵\(A\),进行如下操作:给定\(r,c,l,s\),对于\(x\in[r,r+l)\),\(y\in[c,x-r+c]\),给\(A_{x,y}\)加上\(s\),也就是以\((r,c)\)为左上角的下三角区域。最后问整个矩形的异或和。\(n\le1000\),\(q\le......
  • 10月12日总结
    一.今天做了什么今天上午学uml,然后去上体育课。体育老师上来阴阳怪气说了一顿,原因是没分组和在他说话时说话。。然后就练排球。下午上数据结构和离散数学课。感觉啥也没学到二.遇到的问题,如何解决无......
  • 2023.10.12python练习关于函数
    #让20以内的奇数写入函数里然后输出三遍defnumber():a=-1whilea<19:a+=2print(a,end="")b=1whileb<=3:b+=1number()print()#输出5次20以内的奇数并输出5次9*9乘法表,都写入一个函数里defwww():x,y=1,1z=......
  • 还有理由不升吗?Windows 12确认 2024年见:设计更高级
    对于那些想要升级Windows12的用户来说,它已经在来的路上了。Intel已经确定,Windows12将于2024年进行“更新”,新的系统将会有更大的突破,比如设计更高级等等。消息人士透露,Windows12的“以网络为中心”或“网络优先”变体主要围绕云和网络技术构建,例如PWA和Edge。此外,新系统还有......
  • 10.12日记
    1, 我们应该怎么使用数据库来实现,我们能不能用Oracle生产库,能不能用TimesTen。 不能,使用Oracle,TimesTen会加大我们项目的预算,使我们的项目用很赚钱,变成赚一点钱的项目,要在我们所有业务支撑系统中推广,每一个实例30W$东西我们坚决不用,所以数据库的机制由我们自己实现,那么必须是......
  • 2023/10/12 博沃创新 面试
    2023年应届生6个月试用期被裁第一次社招16号辞职前4天  心里空落落  对自己很失望面试计7-8min心里大受打击好菜啊1.关于BMS的实现细节上问题对于OCV值怎么校正的?答的太差了 在初始化3s内进行校正  DOD2OCV来实现  又问极化存在很长时间怎么办?没回答上......
  • java10/12今日总结
    1publicclassZoo2{34publicstaticvoidmain(Stringargs[])5{67Feederf=newFeeder("小李");89//饲养员小李喂养一只狮子1011f.feedLion(newLion());1213//饲养员小李喂养十......
  • ST12 Trace – Step by step instruction on how to use it for analysis
    ST12介绍ST12性能分析工具的使用分如下三个步骤:设置跟踪参数开始跟踪收集跟踪数据分析跟踪数据跟踪参数分类:跟踪对象(TraceFor)跟踪类型(TypeofTrace)跟踪对象ST12可以捕获4种类型的数据“User/Tasks”,“WorkProcess”,“CurrentMode”和“ForaSchedule”......