函数以递归逆转链接的列表
Function to reverse a linked list recursively
我试图编写此功能以逆转单链接列表,而我在这里找不到问题。
void reverse(node *&c, node *&p){
if(c = NULL){
c = p;
return;
}
node *n = c->next;
c->next = p;
p = c;
c = n;
reverse(c, p);
}
c =电流节点,p =先前的节点,n =下一个节点。
我在Internet上找到了具有返回类型的'node*'的多个解决方案,还有其他一些解决方案,但我想找到我的实现问题
您的条件if(c = NULL)
中有一个分配。这是有效的c/c ,并将null分配给c。然后,分配(NULL)的结果被用作您的IF-Statement中的条件,然后将始终评估false。
用平等的比较替换分配(==
)
在您的条件下使用副作用是不良的实践,应避免。这可能很难找到错误。即使您想要的是您想要的,也应该在IF语句之前使用它,然后检查变量。
其他不良副作用可能是诸如if (someExpression && (a++ == 5))
之类的东西,其中可能会根据编译器设置增加或不会增加。
在您的if语句中,您将null分配给c。用" =="替换" ="。我喜欢更改ordwrite,例如(null ==变量),因为如果我错过一个" =",我会收到一个错误。
相关文章:
- 从链接列表c++中删除一个项目
- 读取文件的最后一行并输入到链接列表时出错
- 下面是我为检测链接列表中的循环而制作的代码
- 有人能帮我处理这个链接列表吗?C++
- C++ 创建包含链表和字符串的对象的链接列表时出错
- 你能检查一下为什么在这个代码中从链接列表中删除项目不起作用吗
- 为什么它只打印双链接列表的第一个值,而我的程序却崩溃了
- 链接列表运算符重载没有打印出我想要的内容
- 链接列表在 cpp 中包含不同的对象类
- 创建一个棋盘格或"Interweave"两个链接列表。IE 更改两个链表的指针
- 如何在构建链接列表时调整头、尾指针
- Shared_ptr双链接列表内存泄漏
- 为什么每当我尝试运行此链接列表删除功能时都会收到分段错误错误?
- 在链接列表中查找元素 - C++
- 删除链接列表中剩余的最后一个节点
- 只有我的"链接列表"中的第一个节点正在打印
- 避免在使用链接列表从 deque 中删除最后一个节点时出现内存泄漏
- C++ 分段错误:11 错误,同时编码将两个数字相加的链接列表
- 如何在C / C++中正确实现链接列表而不会使程序崩溃
- 将元素插入链接列表