错题本之<数据结构>

  1. 已知指针 p 指向单向不循环链表中的某一个节点,且不知道头结点。
    问:如何删除 p 指向的节点?

答:

如果 p 指向的不是最后一个节点

定义一个指针 q 保存 p->next; 然后将 q 的数据域和指针域都覆盖到 p 指向的节点中

最后释放 q 指向的节点即可。

q = p->next;

p->data = q->data;

p->next = q->next;

free(q);

q = NULL;

如果 p 指向的是最后一个节点了,就只能free(p)了,且没法修改倒数第二节点的指针域了

  1. 问:如何通过一趟遍历找到单向不循环链表的中点?

答:可以通过 快慢指针 实现

定义两个指针 p q 都指向链表开头

然后开始循环, p每次走2步,q每次走1步

当 p 走到结尾时,q 指向的就是链表的中点

//如果是代码实现 要注意 得保证 p->next 不是NULL 才能取 p->next->next

while(NULL != p || NULL != p->next){

p = p->next->next;

q = q->next;

}

  1. 顺序表(数组)和链表有什么区别?

答: 链表增删容易,O(n)查找难

顺序表增删难,O(1)查找容易;

顺序表需要提前确定长度,扩展空间难度较大

链表用多大空间就申请几个空间,扩建难度低

相关推荐
散峰而望6 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
冷凝雨6 小时前
复数乘法(C & Simulink)
c语言·开发语言·信号处理·simulink·dsp
智者知已应修善业7 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
LYFlied7 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
历程里程碑8 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
量子炒饭大师8 小时前
Cyber骇客的逻辑节点美学 ——【初阶数据结构与算法】二叉树
c语言·数据结构·c++·链表·排序算法
量子炒饭大师9 小时前
Cyber骇客神经塔尖协议 ——【初阶数据结构与算法】堆
c语言·数据结构·c++·二叉树·github·
XLYcmy10 小时前
TarGuessIRefined密码生成器详细分析
开发语言·数据结构·python·网络安全·数据安全·源代码·口令安全
KingRumn10 小时前
DBUS源码剖析之DBusMessage数据结构
linux·服务器·数据结构
Herbert_hwt10 小时前
C语言赋值操作符详解:从基础使用到避坑指南
c语言