检查链接列表中的重复项
checking for duplicates in link list
bool isduplicate if(p==nullptr) { p->next=q; q->value=x; } while (p!=nullptr) { p=p->next; } //arrived at NULL ptr p->next=q; q->value=x; q->next=nullptr; return q; }
逻辑是错误的。 电流不等于 while 循环开始时的流道,while 循环内的任何内容都不会使它们彼此相等。最终,您将取消引用空指针。
正确的逻辑比你拥有的更简单。试试这个
current = p;
while (current != nullptr)
{
runner = current->next;
while (runner != nullptr)
{
if (runner->value == current->value)
return true;
runner = runner->next;
}
current = current->next;
}
return false;
你没有检查内部循环中的空current
(或runner
)指针,这可能意味着迟早要么为空,然后你这样做
if(runner->value == current->value)
或
current = current->next;
取消引用空指针是未定义的行为,并且很可能导致崩溃。
相关文章:
- 从链接列表c++中删除一个项目
- 读取文件的最后一行并输入到链接列表时出错
- 下面是我为检测链接列表中的循环而制作的代码
- 有人能帮我处理这个链接列表吗?C++
- C++ 创建包含链表和字符串的对象的链接列表时出错
- 你能检查一下为什么在这个代码中从链接列表中删除项目不起作用吗
- 为什么它只打印双链接列表的第一个值,而我的程序却崩溃了
- 链接列表运算符重载没有打印出我想要的内容
- 链接列表在 cpp 中包含不同的对象类
- 创建一个棋盘格或"Interweave"两个链接列表。IE 更改两个链表的指针
- 如何在构建链接列表时调整头、尾指针
- Shared_ptr双链接列表内存泄漏
- 为什么每当我尝试运行此链接列表删除功能时都会收到分段错误错误?
- 包含链接列表的链接列表给出了堆的损坏错误:原因
- C 链接列表创建链接列表的链接列表
- 检查链接列表中的重复项
- 标准模板库列表 - 双重链接或循环链接
- 正在检查链接列表(C++)中的用户输入
- 检查链接列表的末尾
- Qt -用预处理器指令检查链接的.lib在windows上的可用性