zoukankan      html  css  js  c++  java
  • C 二叉树 1

    二叉链表:

    #define
    _CRT_SECURE_NO_WARNINGS #include <stdlib.h> #include <string.h> #include <stdio.h> //1 typedef struct BiTNode { int data; struct BiTNode *lchild, *rchild; }BiTNode; typedef struct BiTNode * BiTree; //2 //第二种表示方法 三叉链表 //三叉链表 typedef struct TriTNode { int data; //左右孩子指针 struct TriTNode *lchild, *rchild; struct TriTNode *parent; }TriTNode, *TriTree; //双亲链表 #define MAX_TREE_SIZE 100 typedef struct BPTNode { int data; int parentPosition; //指向双亲的指针 //数组下标 char LRTag; //左右孩子标志域 }BPTNode; typedef struct BPTree { BPTNode nodes[100]; //因为节点之间是分散的,需要把节点存储到数组中 int num_node; //节点数目 int root; //根结点的位置 //注意此域存储的是父亲节点在数组的下标 }BPTree; //用这个数据结构能表达出一颗树。。。能,怎么表达?不能why void main() { BPTree myTree; // myTree.root = 0; //数组的0号位置 是根结点 myTree.nodes[0].data = 'A'; //B myTree.nodes[1].data = 'B'; myTree.nodes[1].parentPosition = 0; myTree.nodes[1].LRTag = 1; //C myTree.nodes[2].data = 'C'; myTree.nodes[2].parentPosition = 0; myTree.nodes[2].LRTag = 2; system("pause"); } void main11() { BiTNode nodeA, nodeB, nodeC, nodeD, nodeE; nodeA.lchild = NULL; nodeA.rchild = NULL; nodeA.data = 0; memset(&nodeA, 0, sizeof(BiTNode)); memset(&nodeB, 0, sizeof(BiTNode)); memset(&nodeC, 0, sizeof(BiTNode)); memset(&nodeD, 0, sizeof(BiTNode)); memset(&nodeE, 0, sizeof(BiTNode)); nodeA.data = 1; nodeA.lchild = &nodeB; nodeA.rchild = &nodeC; nodeB.lchild = &nodeD; nodeC.lchild = &nodeE; printf("hello... "); system("pause"); return ; }

    中序非递归:

    #include <iostream>
    using namespace std;
    
    #include "stack"
    
    
    
    
    //1 
    typedef struct BiTNode
    {
        int        data;
        struct BiTNode *lchild, *rchild;
    }BiTNode;
    
    typedef struct BiTNode * BiTree;
    
    //递归 中序遍历
    void InOrder(BiTNode *T)
    {
        if (T == NULL)
        {
            return ;
        }
    
        if (T->lchild != NULL)
        {
            InOrder(T->lchild);
        }
    
        printf("%d ", T->data); //
    
        if (T->rchild != NULL)
        {
            InOrder(T->rchild);
        }
    }
    
    
    BiTNode *  GoFarLeft(BiTNode *T, stack<BiTNode *> &s)
    {
        if (T ==NULL)
        {
            return NULL;
        }
        while (T->lchild != NULL) //一直往左走 ,找到中序遍历的起点
        {
            s.push(T);
            T = T->lchild; //让指针下移 
        }
        return T; //
    }
    
    void MyInOrder(BiTNode *T)
    {
        stack<BiTNode *> s; //
        BiTNode *t = GoFarLeft(T, s); //一直往左走 找到中序遍历的起点
    
        while (t != NULL)
        {
            printf("%d ", t->data);
    
            //若结点 有右子树,重复步骤1
            if (t->rchild != NULL)
            {
                t = GoFarLeft(t->rchild, s);
            }
            //若结点 没有右子树 看栈是否为空
            else if ( !s.empty() )
            {
                t = s.top(); //把栈顶弹出 
                s.pop();
            }
            else
            {
                t = NULL;
            }
        }
    }
    
    void main()
    {
        BiTNode  nodeA, nodeB, nodeC, nodeD, nodeE;
    
        nodeA.lchild = NULL;
        nodeA.rchild = NULL;
        nodeA.data = 0;
        memset(&nodeA, 0, sizeof(BiTNode));
        memset(&nodeB, 0, sizeof(BiTNode));
        memset(&nodeC, 0, sizeof(BiTNode));
        memset(&nodeD, 0, sizeof(BiTNode));
        memset(&nodeE, 0, sizeof(BiTNode));
    
        nodeA.data = 1;
        nodeB.data = 2;
        nodeC.data = 3;
        nodeD.data = 4;
        nodeE.data = 5;
    
        nodeA.lchild = &nodeB;
        nodeA.rchild = &nodeC;
        nodeB.lchild = &nodeD;
        nodeC.lchild = &nodeE;
    
        printf("
    中序遍历递归算法");
        InOrder(&nodeA);
    
        printf("
    中序遍历非递归算法");
        MyInOrder(&nodeA);
    
        
    
        
        cout<<"hello..."<<endl;
        system("pause");
        return ;
    }

    数的操作:

    #define  _CRT_SECURE_NO_WARNINGS 
    #include <stdlib.h>
    #include <string.h>
    #include <stdio.h>
    
    
    //1 
    typedef struct BiTNode
    {
        int        data;
        struct BiTNode *lchild, *rchild;
    }BiTNode;
    
    typedef struct BiTNode * BiTree;
    
    //先序遍历
    void preOrder(BiTNode *T)
    {
        if (T == NULL)
        {
            return ;
        }
        printf("%d ", T->data); //
    
        if (T->lchild != NULL)
        {
            preOrder(T->lchild);
        }
    
        if (T->rchild != NULL)
        {
            preOrder(T->rchild);
        }
    }
    
    
    void InOrder(BiTNode *T)
    {
        if (T == NULL)
        {
            return ;
        }
        
        if (T->lchild != NULL)
        {
            InOrder(T->lchild);
        }
    
        printf("%d ", T->data); //
    
        if (T->rchild != NULL)
        {
            InOrder(T->rchild);
        }
    }
    
    
    
    void PostOrder(BiTNode *T)
    {
        if (T == NULL)
        {
            return ;
        }
    
        if (T->lchild != NULL)
        {
            PostOrder(T->lchild);
        }
    
        if (T->rchild != NULL)
        {
            PostOrder(T->rchild);
        }
    
        printf("%d ", T->data); //
    }
    
    /*
            1
        2        3
    4        5
    */
    
    
    //求树的叶子结点的个数
    
    int  sum = 0;
    void coutLeafNum(BiTNode *T)
    {
        if (T == NULL)
        {
            return ;
        }
        if (T->lchild == NULL && T->rchild ==NULL)
        {
            sum ++;
        }
        coutLeafNum(T->lchild); //求左子树的叶子结点个数
    
        coutLeafNum(T->rchild); //求右子树 叶子结点个数
    }
    
    
    //1 递归函数遇上全局变量 ===>函数参数
    //2 //遍历的本质 强化
        //访问树的路径是相同的,是不过是计算叶子结点的时机不同....
    
    void coutLeafNum2(BiTNode *T, int *sum)
    {
        if (T == NULL)
        {
            return ;
        }
        if (T->lchild == NULL && T->rchild ==NULL)
        {
            //*sum++;
            //*sum = *sum +1;
            (*sum )++ ;  //++后置 ++   先*p 然后sum++
                        //1   p++
    
                        //1 是让实参++ 而不是让地址++
        }
        
        coutLeafNum2(T->lchild, sum); //求左子树的叶子结点个数
    
        coutLeafNum2(T->rchild, sum); //求右子树 叶子结点个数
    }
    
    
    void coutLeafNum3(BiTNode *T, int *sum)
    {
        if (T == NULL)
        {
            return ;
        }
    
        coutLeafNum3(T->lchild, sum); //求左子树的叶子结点个数
    
    
        coutLeafNum3(T->rchild, sum); //求右子树 叶子结点个数
    
        if (T->lchild == NULL && T->rchild ==NULL)
        {
            (*sum )++ ;   //计算叶子结点
        }
    }
    
    //求树的高度
    int Depth(BiTNode *T)
    {
        int  depthval = 0;
        int  depthLeft = 0, depthRight = 0;
    
        if (T == NULL)
        {
            return 0;
        }
    
        depthLeft =  Depth(T->lchild); //求左子树的高度
        depthRight = Depth(T->rchild); //求右子树的高度
    
        //1 + 谁大要谁
        depthval = 1 + ( (depthLeft>depthRight) ? depthLeft :depthRight );
        return depthval;
    }
    
    //copy二叉树
    BiTNode* CopyTree(BiTNode *T)
    {
        BiTNode *newlptr = NULL;
        BiTNode *newRptr = NULL;
        BiTNode *newNode = NULL;
    
        if (T == NULL)
        {
            return NULL;
        }
    
        newlptr = CopyTree(T->lchild);
        newRptr = CopyTree(T->rchild);
    
    
    
        //new结点
        newNode = (BiTNode *)malloc(sizeof(BiTNode)) ; //
        if (newNode == NULL)
        {
            return NULL;
        }
    
    
    
        newNode->data = T->data; //从旧树中copy数据
        newNode->lchild = newlptr; //新的左子树
        newNode->rchild = newRptr; //新的右子树
        return newNode;
    }
    
    
    void main()
    {
        BiTNode  nodeA, nodeB, nodeC, nodeD, nodeE;
    
        nodeA.lchild = NULL;
        nodeA.rchild = NULL;
        nodeA.data = 0;
        memset(&nodeA, 0, sizeof(BiTNode));
        memset(&nodeB, 0, sizeof(BiTNode));
        memset(&nodeC, 0, sizeof(BiTNode));
        memset(&nodeD, 0, sizeof(BiTNode));
        memset(&nodeE, 0, sizeof(BiTNode));
    
        nodeA.data = 1;
        nodeB.data = 2;
        nodeC.data = 3;
        nodeD.data = 4;
        nodeE.data = 5;
    
        nodeA.lchild = &nodeB;
        nodeA.rchild = &nodeC;
        nodeB.lchild = &nodeD;
        nodeC.lchild = &nodeE;
    
        //拷贝二叉树
        {
            BiTNode *newTree = NULL;
            newTree = CopyTree(&nodeA);
            printf("
    中序遍历新树:");
            InOrder(newTree);
        }
    
        {
            //求树的高度
            int depth = Depth(&nodeA);
            printf("depth:%d 
    ", depth);
    
        }
    
        //计算树的叶子结点
        {
            int mysum = 0;
            coutLeafNum(&nodeA);
            printf("sum:%d 
    ", sum);
    
            coutLeafNum2(&nodeA, &mysum);
            printf("mysum:%d 
    ", mysum);
    
            mysum = 0;
            coutLeafNum3(&nodeA, &mysum);
            printf("mysum:%d 
    ", mysum);
    
            
        }
    
        //printf("
    先序遍历树: ");
        //preOrder(&nodeA);
    
        printf("
    中序遍历树: ");
        InOrder(&nodeA);
    
        //printf("
    后序遍历树: ");
        //PostOrder(&nodeA);
    
        system("pause");
    }
  • 相关阅读:
    Navicat Premium 12 破解汉化64位 windows版本
    Tkinter入门简明教程
    python tkinter-消息框、对话框、文件对话框
    python中ui自动化selenium方法封装分享
    Windows利用EasyWebSvr起web服务
    Windows安装mysql服务端
    北京个人所得税纳税记录打印
    Java并发之ReentrantReadWriteLock源码解析(二)
    Java并发之ReentrantReadWriteLock源码解析(一)
    Java并发之Semaphore源码解析(二)
  • 原文地址:https://www.cnblogs.com/yaowen/p/4812575.html
Copyright © 2011-2022 走看看