coisini002 2023-03-26 14:37 采纳率: 51.3%
浏览 49
已结题

若以h1为表头指针的链表是非循环的,以h2为表头指针的链表是循环的

设有两个长度为n的单链表,结点类型相同。若以h1为表头指针的链表是非循环的,以h2为表头指针的链表是循环的,则(B)
A对于两个链表来说,删除第一个结点的操作,其时间复杂度都是O(1)
B对于两个链表来说,删除最后一个结点的操作,其时间复杂度都是O(n)
C循环链表要比非循环链表占用更多的内存空间
D h1和h2是不同类型的变量
解释一下A选项

  • 写回答

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)。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 4月2日
  • 已采纳回答 4月2日
  • 创建了问题 3月26日

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改