标题:怎么插入而不是替换一个节点(向一个初始为空的单链表中逐个插入节点)
只看楼主
Keyword
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2019-7-21
结帖率:0
已结贴  问题点数:20 回复次数:1 
怎么插入而不是替换一个节点(向一个初始为空的单链表中逐个插入节点)
第一次调用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);

}
搜索更多相关主题的帖子: 插入 替换 节点 struct NULL 
2019-07-21 12:40
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:20 
struct t_Node newNode; 是个局部变量,你将它加入到链表中?
另外,代码好多的错误。

2019-07-22 08:49



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-495968-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.233922 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved