两次删除链表有什么区别?
What's difference between two deletion of linked-list?
我写了两个方法两个删除给定节点,尽管它们是相同的。但是,它们给出了不同的结果。
首先,
node *q = c->next;
c->data = q->data; second: c->data = c->next->data;
c->next = q->next; c->next = c->next->next;
delete q; delete c->next;
我尝试示例(链接列表:1,2,3,4,5,6,7,8,9,10和c == 3)第一种方法给出了结果:1,2,4,5,6,7,8,9,10,这是我想要的
但第二个给予:1,2,4,-572662307我不明白什么有所不同。
一个显着的区别是,在第一个之后, c->next
将指向(在算法之前) c->next->next
。第二个之后,c->next
将指向删除的节点。
另一个区别是,第一个删除了算法之前的 c->next
,而第二个则删除了算法之前曾经为 c->next->next
的节点。
相关文章:
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 在 .h 文件中的类中声明静态变量和在.cpp文件中声明"global"变量有什么区别
- 我是C++编程的新手,这些代码之间有什么区别,我应该使用哪一个
- 返回常量对象引用 (getter) 和仅返回字符串有什么区别?
- Qt:remove() 和 rmdir() 有什么区别
- 这 4 个 lambda 表达式之间有什么区别?
- 将向量作为类>(值)<向量启动和向量<类>[值]有什么区别
- typedef 枚举和枚举类有什么区别?
- &C::c 和 &(C::c) 有什么区别?
- ascii 和 unicode 在处理级别有什么区别吗?
- C 中的常量限定符和 C++ 中的常量限定符有什么区别?
- "ABC" 和 "ABC" ) 在C++中有什么区别?
- 空指针常量 (nullptr)、空指针值和空成员指针值之间有什么区别?
- 引用捕获和在 lambda 中通过引用发送参数有什么区别 (C++)
- 两种访问I2C总线的方法有什么区别?
- 两种模板示例有什么区别?
- 这两种C++语法之间有什么区别?
- lua 5.0.2 模块和 5.3.5 有什么区别?
- C++中"typedef"、"using"、"namespace"和"using namespace"有什么区别?
- std::enable_if 和 std::enable_if_t 有什么区别?