话不多说,摘录网上的理解,貌似理解一些了。
- typedef struct Node
- {
- Element data;
- struct Node * next;
- }Node, * Linklist;
typedef struct node
{
int data;
PNode next;
}PNode,*Linklist;
可以理解为:
struct
node
{
int
data
;
struct
node
*
next
;
};
typedef
struct
node
PNode
;
typedef
struct
node
*
Linklist
;
首先
在C中定义一个结构体类型要用typedef:
typedef struct Student
{
int a;
}Stu;
于是在声明变量的时候就可:Stu stu1;
如果没有typedef就必须用struct Student stu1;来声明
这里的Stu实际上就是struct Student的别名。
typedef struct Student
{
int a;
}Stu;
于是在声明变量的时候就可:Stu stu1;
如果没有typedef就必须用struct Student stu1;来声明
这里的Stu实际上就是struct Student的别名。
1.struct Node{};定义了一个stuct Node类型的结构体(C语言规定结构体类型为struct Node,而不是Node);
2.typdef struct Node Node;可能人家觉得老写struct Node 有点烦,于是给struct Node 取了一个别名Node;
3.typedef Node * Linklist;由于最终目的是要定义一个链表,即在主函数里要出现这样的定义:Linklist L;所以就在这里将 Node *取个别名为Linklist。
4.至于在各种链表操作函数虚参中出现的Linklist * L以及Linklist L以及Linklist &L等问题,其实都是要看在主函数中是如何调用这些函数的。