V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
insaneDream
V2EX  ›  编程

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

  •  
  •   insaneDream · 2014-10-02 23:24:03 +08:00 · 3099 次点击
    这是一个创建于 3707 天前的主题,其中的信息可能已经有所发展或是发生改变。
    typedef struct TreeNode *PtrToNode;
    typedef struct PtrToNode Tree;

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

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