怎么插入而不是替换一个节点(向一个初始为空的单链表中逐个插入节点)
第一次调用ListInsert()时,变量newNode 的内存单元的地址为0xfffffffdf50,第二次调用ListInsert()时,*L=0xfffffffdf50, **L = fist node,就是我第一次插入的节点。但是当我创建第二个节点时,newNode的内存地址还是0xfffffffdf50,我如果给第二个节点赋值,就会修改 **L,这样,就是替换第一个节点而不是在尾部插入了,请问,我想要插入应该怎么改?{
struct t_Data m_Data;
struct t_Node *m_nextNode;
}
typedef struct Node* t_LinkedList;
void ListInsert(t_LinkedList* L, int position, struct t_Data newData)
{
if (!*L)
{
struct t_Node newNode;
newNode.m_Data = newData;
newNode.m_nextNode = NULL;
(*L) = &newNode;
}
/* first Node is not NULL */
else
{
t_LinkedList anIterator;
anIterator = (*L);
if (!(*anIterator).m_nextNode)
{
struct t_Node newNode;
newNode.m_Data = newData;
newNode.m_nextNode = NULL;
(*anIterator).m_nextNode = &newNode;
}
}
}
int main()
{
t_LinkedList aLinkedList;
aLinkedList = NULL;
ListInsert(&aLinkedList,1,data1);
ListInsert(&aLinkedList,2,data2);
}