前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >372. 在O(1)时间复杂度删除链表节点复制节点的值

372. 在O(1)时间复杂度删除链表节点复制节点的值

作者头像
和蔼的zhxing
发布2018-09-04 11:36:12
7290
发布2018-09-04 11:36:12
举报

给定一个单链表中的一个等待被删除的节点(非表头或表尾)。请在在O(1)时间复杂度删除该链表节点。

Linked list is 1->2->3->4, and given node 3, delete the node in place 1->2->4

复制节点的值

删除节点一般的做法是找到要删除节点的前一个节点,然后把这个节点的next指针指向要删除的节点的下一个节点,一般都是这样做的,这个题要求O(1)的时间复杂度,显然是不允许遍历搜索的,而且给定的是节点的指针。 我们要删除这个节点,但是我们通过操作只能删除它的下一个节点,那我们能不能把下一个节点的数据拷贝过来到这个节点,然后把下个节点删除,这样就相当于把这个节点删除了 我怎么会想到这个方法呢?哎,刷题容易怀疑智商! 写起来就不是一般的简单了,题目中默认此节点不是表头或表尾,所以这种方法是完全可以的,如果是表尾的话就不好玩了!

  void deleteNode(ListNode * node) {
        node->val=node->next->val;
        node->next=node->next->next;
        // write your code here
    }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.01.04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 复制节点的值
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档