设有两个长度为n的单链表,结点类型相同。若以h1为表头指针的链表是非循环的,以h2为表头指针的链表是循环的,则(B)
A对于两个链表来说,删除第一个结点的操作,其时间复杂度都是O(1)
B对于两个链表来说,删除最后一个结点的操作,其时间复杂度都是O(n)
C循环链表要比非循环链表占用更多的内存空间
D h1和h2是不同类型的变量
解释一下A选项
若以h1为表头指针的链表是非循环的,以h2为表头指针的链表是循环的
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- IT_service_mesh 2023-03-26 14:41关注
参考GPT和自己的思路:答案是B。
对于h1为表头指针的非循环链表,删除最后一个节点需要遍历整个链表,其时间复杂度为O(n)。同样地,对于h2为表头指针的循环链表,删除最后一个节点也需要遍历整个链表,其时间复杂度也是O(n)。
A选项中提到删除第一个节点的操作,其时间复杂度都是O(1),这是不正确的。对于h1为表头指针的非循环链表,删除第一个节点需要将表头指针指向第二个节点,其时间复杂度为O(1);而对于h2为表头指针的循环链表,删除第一个节点同样需要找到最后一个节点的前一个节点,然后将其指向第一个节点的下一个节点,其时间复杂度为O(n)。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 网络设备配置与管理这个该怎么弄
- ¥20 机器学习能否像多层线性模型一样处理嵌套数据
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器