其次,新的节点生成,会通过new或malloc来申请空间,其返回值是个指针,这时一般要用指针变量p2来接收这个指针,然后将链表尾节点的next赋值成这个p2的内容,p2指向的next再赋值成NULL成为尾节点。最后,如果需要在链表中插入,就需要一个指针p1指向当前节点,另一个p2指向当前节点之后的节点,然后将p1的next赋值成新节点指针,新节点指针的next赋值成p2,完成插入。总体来说,所谓p1和p2是临时辅助性的变量,是为方便使用的中间变量,这个从方便出发申请的工作变量也无需节省。

用数组描述的链表,即称为静态链表。在C语言中,静态链表的表现形式即为结构体数组,结构体变量包括数据域data和游标CUR。
举例:有静态链表S中存储这线性表(a,b,c,d,f,g,h,i),Maxsize=11,要在第四个元素后插入元素e,方法是:先在当前表尾加入一个元素e,即:S[9].data = e;然后修改第四个元素的游标域,将e插入到链表中,即:S[9].cursor = S[4].cursor; S[4].cursor = 9;,接着,若要删除第7个元素h,则先顺着游标链通过计数找到第7个元素存储位置6,删除的具体做法是令S[6].cursor = S[7].cursor。