首页 > 其他 > 详细

二叉树先序存储广义表输出

时间:2019-06-04 00:39:40      阅读:119      评论:0      收藏:0      [点我收藏+]
#include<stdio.h>
#include<stdlib.h>
#define maxSize 50 
typedef struct Node{
    int data[maxSize];
    int n;
}Sqbtree;

void createSqbtree(Sqbtree &L,char pre[],int n, int &S){
    char ch =pre[S++];
    if(ch == ;) return ;
    if(ch != #){
        L.data[n] = ch;
        createSqbtree(L,pre,2*n+1,S);
        createSqbtree(L,pre,2*n+2,S);
    }
}


void printSqbtree(Sqbtree L,int n){
    if(L.data[n] != #){
        printf("%c",L.data[n]);
        if(L.data[2*n+1] != # && L.data[2*n+2] != #)
            printf("(");
        printSqbtree(L,2*n+1);
        if(L.data[n*2+2] != #)
            printf(",");
        printSqbtree(L,2*n+2);
        if(L.data[2*n+1] != # && L.data[2*n+2] != #)
            printf(")");
    }
}


int main(){
    Sqbtree L;
    int s=0,k=0;
    char ch[maxSize] = {a,b,c,#,#,e,#,#,f,g,#,#,h,#,#,;};
    for(int i = 0;i < maxSize;i++){
        L.data[i] = #;
    }
    createSqbtree(L,ch,k,s);
    printSqbtree(L,k);
}

 

二叉树先序存储广义表输出

原文:https://www.cnblogs.com/L1Gd0ng/p/10970816.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!