这篇感觉叙述有点乱,最好自己调试一下,把地址,结构图,画一下。
首插法虽然简单,但节点的次序和输入的顺序相反。
若要顺序一致则可以采用尾插法。
若要理解,还是要写代码,看内存啊,文章真是没法描述。
#include <stdio.h>
#include"3.h"
//尾插法
#define datatype int
typedef struct node
{
datatype data;
struct node *next;
}Linklist;
Linklist *head,*p,*r;
void main()
{
char ch;
ch=getchar();
r=(Linklist *)malloc(sizeof(Linklist));
head=r;
while(ch!='$')
{
p=(Linklist *)malloc(sizeof(Linklist));
p->data=ch;
r->next=p;
r=p;
ch=getchar();
}
}
开始运行,输入字符‘K’,ch=‘K’,且申请一片内存空间,首地址值放在r,赋值给head,r=head=0x04e3fb8。内存空间内容为空,生成新节点,它也有数据域和指针域,等下我们只用指针域用于做访问入口。
r=head=0x04e3fb8,说明r和head这两个指针,都能访问0x04e3fb8地址开始的那片内存,可以写入
然后判断进入循环,再申请一片空间,地址是0x004e06e0,生成新节点1,用于放ch 。
把ch=K放入新节点的数据域,指针域先不处理,因为它要指向下一个节点,现在还没有申请。p->data=ch。
现在地址0x004e06e0开始的这片内存,放在数据,指针为空。
再把刚刚的r=head=0x04e3fb8,头结点内存的指针域,指向地址是0x004e06e0新节点1的这片内存空间。即 r->next = p = 0x004e06e0
现在r还等于head等于0x04e3fb8,它们还能访问这片内存呢。注意区分r,r->next,都是指针,内容都是值
r=p
现在r的值终于变了,r=0x004e06e0。现在r能访问0x004e06e0开始的这片内存了,也就是新节点1.
内存里面,数据域data=75,指针域next为空
然后再输入字符‘换行符’,ch=10。
申请一片内存,首地址p=0x004e0728,生成新节点2。
p->next进行赋值,0x004e0728新节点2数据域ch=10, 指针域先不处理,因为它要指向下一个节点,现在还没有申请。
再把新节点1指针域指向新节点2,首地址p=0x004e0728,即 r->next=p
继续创建新节点,直到输入字符‘$’。我们可以从head开始访问数据了。