typedef struct LNode{ ElemType data; struct LNode *next; }LNode, *LinkList;中的LNode和*LiknList有什么区别
时间: 2024-03-12 21:41:05 浏览: 132
在这个typedef语句中,LNode是一个结构体类型别名,它定义了一个包含数据成员和指向下一个节点的指针成员的结构体。而*LinkList是一个指向LNode结构体的指针类型的别名。
具体来说,LNode表示一个具体的结构体类型,它可以用来定义LNode类型的变量。而*LinkList表示一个指向LNode类型的指针,它可以用来指向LNode类型的对象或者链表的头节点。
通过这种方式,我们可以方便地定义和操作链表,使用LinkList作为链表的头指针,通过指针操作来实现链表的插入、删除、遍历等操作。
相关问题
解析这段代码typedef struct LNode{ ElemType data; struct LNode *next; LNode,*LinkList;
这段代码定义了一个结构体类型 LNode,其中包含了两个成员变量:data 和 next。data 是一个类型为 ElemType 的变量,next 是一个指向 LNode 结构体类型的指针,即指向下一个结构体变量的指针。
此外,代码中还定义了一个 LinkList 类型,它是指向 LNode 结构体类型的指针。这个指针可以用来指向链表的头节点,从而实现对整个链表的操作。
值得注意的是,这段代码中有一个小错误:在定义 LNode 结构体时,第三个成员变量 LNode 多了一个逗号。应该将其修改为:
```
typedef struct LNode{
ElemType data;
struct LNode *next;
} LNode, *LinkList;
```
这样就可以正确地定义 LinkList 类型了。
typedef int ElemType; typedef int Status; typedef struct Lnode { ElemType data; struct Lnode *next; }Lnode, *LinkList;
这其实是一段 C 语言代码,用于定义一个链表数据结构。具体来说,这段代码分别定义了如下内容:
1. `typedef int ElemType;`:定义了一个别名 `ElemType`,它代表了链表节点中存储的数据类型,这里是整型(int)。
2. `typedef int Status;`:定义了一个别名 `Status`,它代表了函数返回值类型,这里也是整型(int)。
3. `typedef struct Lnode`:定义了一个结构体类型 `Lnode`,它表示链表节点的结构。
4. `{ ElemType data; struct Lnode *next; }`:定义了结构体 `Lnode` 的成员变量,即节点的数据域 `data` 和指向下一个节点的指针域 `next`。
5. `Lnode, *LinkList;`:定义了两个别名 `Lnode` 和 `LinkList`,它们都是指向 `struct Lnode` 的指针类型。其中,`Lnode` 表示链表节点的类型,`LinkList` 表示链表的头指针类型。
这段代码的作用是方便定义和使用链表数据结构。通过定义别名 `ElemType` 和 `Status`,可以方便地更改节点数据类型和函数返回值类型。通过定义结构体 `Lnode` 和指针类型 `LinkList`,可以方便地创建和操作链表。
阅读全文