V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
insaneDream
V2EX  ›  编程

C 语言二叉树节点声明的疑问

  •  
  •   insaneDream · Oct 2, 2014 · 3522 views
    This topic created in 4228 days ago, the information mentioned may be changed or developed.
    typedef struct TreeNode *PtrToNode;
    typedef struct PtrToNode Tree;

    struct TreeNode
    {
    ElementType Element;
    Tree Left;
    Tree Right;
    };

    第一个PtrToNode已经声明为一个指向TreeNode结构体的一个指针类型,
    那么第二个的PtrToNode是表示什么? 第二个typedef把它声明为一个结构? 求大神解释一下
    3 replies    2014-10-03 09:32:52 +08:00
    youyongsong
        1
    youyongsong  
       Oct 2, 2014   ❤️ 1
    1. 你第2个定义是错误的应该是 typedef PtrToNode Tree
    其实你把前两行直接复制,然后用Google搜索就会发现错误的。
    2. 纠正完错误后就会发现Tree就是PtrToNode的一个别名而已,这样做可能是教科书上方便学生们理解吧,先用PtrToNode表示一个节点引用,然后再告诉你其实树就是一个节点的引用。(PS:自己认为这样做反而不利于理解了)
    allan888
        2
    allan888  
       Oct 3, 2014   ❤️ 1
    PtrToNode是指向struct TreeNode的指针。
    Tree和PtrToNode是一个意思。
    树也是从一个根节点开始的,所以给指向Node的指针取了两个名字(Tree和PtrToNode)以方便理解。
    xiaoai
        3
    xiaoai  
       Oct 3, 2014   ❤️ 1
    typedef 只是重命名 编译器看来就是把右边的换成左边的再继续编译
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   835 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 19:57 · PVG 03:57 · LAX 12:57 · JFK 15:57
    ♥ Do have faith in what you're doing.