zoukankan      html  css  js  c++  java
  • 数据结构 常用定义


    #ifndef _List_H //#ifndef预编译指令,如果没有定义 _List_H,就执行下面

    struct Node; //Node 结构体变量声明,就像int a 一样,Node是变量名

    typedef struct Node *PtrToNode; //typedef定义,定义新的类型,这种类型的名字叫做PtrToNode,它的类型是指向Node结构体的指针;

    typedef PtrToNode List; //定义一个链表,其存储的数据格式是Node结构体,名字是List。

    typedef ptrToNode Position; //依旧是PtrToNode类型的指针,只不过换了个名字叫Position而已。

    List MakeEmpty(List L);

    int IsEmpty(List L);

    int IsLast(Position P,List L);

    position Find(ElementType X,ListL, position P);

    void DeleteList(List L);

    int ISlast(Position P);

    Elementytpe Retrieve(Position P); //上面的N个函数从名字上就可以看出来,是对链表进行操作的函数,分别是 清空链表、检查链表是否为空、检查是否Position指向的是链表的最后一个元素、查找指定元素在链表中的位置、删除链表;至于……呃……最后一个 int ISlast(Position P); ……是你打错了吧……

    #endif//预编译指令#ifndef结束。

    struct Node

    {

    ElementType Element; //C语言是没有这个数据类型的,讲数据结构时,用ElemType泛指指某一种数据类型。#define ElemType int
    ElemType 就是 int类型的

    Position Next;

    }; //结构体定义,不说了。

    这样说或许你还是比较迷糊~其实我也觉得说的蛮迷糊的~

    #ifndef的意思是“如果没有定义XXX,就执行下面的代码”,所以很简单,从#ifndef开始到#endif为止中间的内容都是在定义一些代码中要用到的新类型,之所以用#ifndef把他们包含进来,是因为“模块化开发”的思想,在一个软件系统中,这些定义应该是写在.h文件中的,为了防止重复定义,就使用了#ifndef。




    typedef struct Node *PtrToNode;

    typedef PtrToNode List;

    typedef ptrToNode Position;

    第一行定义了一个指向Node结构体的指针类型,这个类型的名字是PtrToNode,也就是说,如果我现在需要定义一个Node*类型的变量,就不用写
    Node * pNode;
    而写
    PtrToNode pNode;
    就好了。

    第二行定义了一个链表,这个很好理解,空链表只有2种形式,一种是null,另一种是有个“哨兵元素”,它的定义是后者。

    第三句同理,依旧是Node*,指向Node结构的指针,只不过又取了个名字叫Position而已。


  • 相关阅读:
    获取指定字符传的长度或者高度
    检测身份证号码是否合法
    tabbar添加小红点
    单例的简单构造
    iOS程序内发短信
    多项式加法运算 使用链表实现
    链表的数组实现
    使用链表实现堆栈
    使用链表实现堆栈
    求最大子列和的几种方法
  • 原文地址:https://www.cnblogs.com/zle1992/p/5338810.html
Copyright © 2011-2022 走看看