- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
到目前为止我还没有太多,但我正在尝试掌握使用链表的窍门。
结构:
struct Node
{
int value;
Node *next;
};
如何将节点添加到列表的末尾?我只是想接受一个指向列表头部的指针和一个 int 值作为新节点添加。当我尝试运行我目前拥有的东西时,我得到了一个异常(exception)。
void addNode(Node* head, int x)
{
Node* temp = new Node;
temp->data = x;
temp->next = NULL;
if(!head)
{
head = temp;
return;
}
else
{
Node* last = head;
while(last->next)
last=last->next;
last->next = temp;
}
}
我还没有真正开始合并这两个列表。我只知道我需要接收 2 个链表(或指向 2 个链表头部的指针?),然后遍历所有节点的列表。
例如:链表 1 有 3 个节点:4、10、20。链表 2 有 4 个节点:2、5、15、60。
合并列表函数将生成一个新的链表,节点为 2,4,5,10,15,20,60。
编辑:在我的主程序中,我像这样调用 addNode 函数:
Node *head = new Node;
insertAtEnd(head,20);
这是正确的还是这可能是异常的原因?
最佳答案
这样做:
void addNode(Node* head, int x)
// here ---------^
然后是:
head = temp; // here
您只是修改了本地 head
指针,它采用从调用者传递的地址值。由于 head
不是对指针的实际引用(它只是一个指针),结果是作为 head
传递的调用者指针保持不变。你永远不会将你分配的节点附加到你的列表中,泄漏内存,这将成为一个悲伤的日子......
改为通过引用传递指针。解决这个问题,然后修复无效的 data
成员,它实际上应该是 value
和一个指向指针的指针,用于遍历列表以找到结尾,结果可能看起来像像这样:
#include <iostream>
struct Node
{
int value;
Node *next;
};
void addNode(Node*& head, int x)
{
Node **pp = &head;
while (*pp)
pp = &(*pp)->next;
*pp = new Node;
(*pp)->value = x;
(*pp)->next = nullptr;
}
void printList(const Node *head)
{
for (; head; head = head->next)
std::cout << head->value << ' ';
std::cout << '\n';
}
void freeList(Node *&head)
{
while (head)
{
Node *p = head;
head = p->next;
delete p;
}
}
int main()
{
Node *head = nullptr;
for (int i=1; i<=5; ++i)
addNode(head, i);
printList(head);
freeList(head);
}
输出
1 2 3 4 5
我将实现实际合并的任务留给您,但这应该足以让您启动并运行一个可管理的列表。
更新:来自 OP 的编辑问题:
Node *head = new Node;
insertAtEnd(head,20);
除了现在是一个完全不同的命名函数之外,您的节点是默认初始化的。在您的情况下,这意味着来自 new Node;
的结果 Node
具有 indeterminate 值 both value
和下一步
。然后您将其传递给您的函数,该函数假定一个确定值(null)来终止您的循环。
这可以通过多种方式解决;上面代码的机制就是这样一种方式。如果列表管理代码理解为 NULL 表示无列表,则无需首先预分配头节点。您的 addNode
原始帖子似乎至少尝试遵循该口头禅。
关于c++ - 合并 2 个链表并附加到链表的末尾 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30523179/
我正在更改链接网址以添加 www.site.com/index.html?s=234&dc=65828 我通过此代码得到的是:site.com/&dc=65828 var target="&dc=65
我在编译过程中收到错误: src/smtp.c:208:1: warning: control reaches end of non-void function [-Wreturn-type] 这是相
这是我的 bootstrap/html 代码: Put email 位置正确,但我希望输入字段的大小延伸到 div 末尾。谁能帮帮我? 最佳答案 只需按百分比指定宽度,如下所示
我正在尝试获取一个像这样的 json 对象: filters = {"filters": myArray}; 并将其附加到 URL 的末尾,使用: this.router.navigate([`/de
这个问题已经有答案了: Remove hash from url (5 个回答) 已关闭 10 年前。 我有一个网站,stepaheadresidents.com ,并且井号 (#) 会自动添加到 u
我有这个代码 $('container a').appendTo('.container'); dzedzdqdqdqzdqdzqdzqdqzdqd Forgot password
为了练习更多 Python 知识,我尝试了 pythonchallenge.com 上的挑战 简而言之,作为第一步,此挑战要求从末尾带有数字的 url 加载 html 页面。该页面包含一行文本,其中有
我对 FS2 很陌生,需要一些有关设计的帮助。我正在尝试设计一个流,它将从底层的 InputStream 中提取 block ,直到结束。这是我尝试过的: import java.io.{File,
我对 FS2 很陌生,需要一些有关设计的帮助。我正在尝试设计一个流,它将从底层的 InputStream 中提取 block ,直到结束。这是我尝试过的: import java.io.{File,
我正在编写一个 ajax 应用程序,并且在 php 脚本中有一个函数: public function expire_user() { $r=array("return"=>'OK');
我正在使用一个QListView,它包装了一个非常简单的列表模型。我想尝试实现类似于某些网页中看到的“无限滚动”的东西。 目前,模型通过最多添加 100 个项目的方法更新(它们取自外部 Web API
运行 cucumber 测试给我以下错误 end of file reached (EOFError) /usr/lib64/ruby/2.0.0/net/protocol.rb:153:in
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我想知道版本命名的具体作用是什么? 喜欢 jquery.js?ver=1.4.4 我的意思是如果我使用像这样的 cdn jquery/1.4.4/jquery.min.js?ver=1.4.4但是另一
" data-fancybox-group="gallery" title="">" alt="" /> 在此代码中 echo $prod['item_image_url'];打印存储在我的表中的图像
我目前使用 Wordpress 作为博客平台,但我想更改为使用 Jekyll 来生成静态页面。在 WordPress 上,我的 URL 使用以下格式: /年/月/日/标题 但我想将其重定向到 /年/月
根据docs这应该是不可能的 Regular expressions cannot be anchored to the beginning or end of a token 尽管如此,它似乎对我有
有没有办法创建 dijit 并将其附加到 div 的末尾?假设我有以下代码: Add Person 我在网上找到了以下代码,但这替换了我的“attendants”div: var personCo
我有这段代码: //execute post (the result will be something like {"result":1,"error":"","id":"4da775
我需要一些函数方面的帮助。 我想编写一个插入链表的函数。但不仅仅是中间,如果必须插入前端或末尾,它也必须起作用。 结构: typedef struct ranklist { i
我是一名优秀的程序员,十分优秀!