当前位置: 首页 > wzjs >正文

网站建设公司经营范围360网站收录提交入口

网站建设公司经营范围,360网站收录提交入口,网站建设 协议书 doc,专门做水果的网站剑指 Offer(第2版)面试题 18:删除链表的节点 剑指 Offer(第2版)面试题 18:删除链表的节点题目一:在 O(1) 时间删除链表结点题目二:删除链表中重复的节点 剑指 Offer(第2版…

剑指 Offer(第2版)面试题 18:删除链表的节点

  • 剑指 Offer(第2版)面试题 18:删除链表的节点
    • 题目一:在 O(1) 时间删除链表结点
    • 题目二:删除链表中重复的节点

剑指 Offer(第2版)面试题 18:删除链表的节点

题目一:在 O(1) 时间删除链表结点

题目来源:

  1. 28. 在 O(1) 时间删除链表结点
  2. LeetCode 237. 删除链表中的节点

算法:

  1. 得到要删除节点的下一个节点 pNext;
  2. 将 pNext->val 赋给 node->val;
  3. 让 node 指向 pNext->next;
  4. delete pNext。

代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution
{
public:void deleteNode(ListNode *node){ListNode *pNext = node->next;node->val = pNext->val;node->next = pNext->next;delete pNext;}
};

复杂度分析:

时间复杂度:O(1)。

空间复杂度:O(1)。

题目二:删除链表中重复的节点

题目来源:29. 删除链表中重复的节点

代码 1:书上的版本,很长,但是没有内存泄漏

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution
{
public:ListNode *deleteDuplication(ListNode *head){if (head == nullptr)return nullptr;ListNode *p = head, *pre = nullptr;while (p){ListNode *pNext = p->next;bool needDelete = false;if (pNext && p->val == pNext->val)needDelete = true;if (needDelete){int value = p->val;ListNode *pToBeDel = p;while (pToBeDel && pToBeDel->val == value){pNext = pToBeDel->next;delete pToBeDel;pToBeDel = pNext;}if (pre == nullptr)head = pNext;elsepre->next = pNext;p = pNext;}else{pre = p;p = p->next;}}return head;}
};

代码 2:简化版,没有 delete 重复节点,存在内存泄漏

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution
{
public:ListNode *deleteDuplication(ListNode *head){auto dummy = new ListNode(-1); // 建立虚拟头结点dummy->next = head;			   // 虚拟头结点指向头结点auto p = dummy;while (p->next) // p的下一个节点不为空{auto q = p->next;// q的下一个节点不为空,且q的下一个节点的值等于p的下一个节点的值while (q->next && q->next->val == p->next->val)q = q->next;// 如果q==p的下一个节点 p=qif (q == p->next)p = q;// 如果不是说明存在重复元素,则p指向q的下一个节点即非重复节点elsep->next = q->next;}return dummy->next;}
};

复杂度分析:

时间复杂度:O(n),其中 n 是链表的长度。

空间复杂度:O(1)。

http://www.dtcms.com/wzjs/353773.html

相关文章:

  • 做电影网站会不会涉及版权问题网上广告怎么推广
  • 给别人做网站用什么长沙seo网站排名优化公司
  • 城子河网站建设美国今天刚刚发生的新闻
  • 做美国代购需要知道的网站seo关键词排名优化怎么收费
  • 东莞制作公司网站培训机构咨询
  • 新企业在哪里做网站好网络营销论坛
  • 科技服务公司网站模版腰椎间盘突出压迫神经腿疼怎么治
  • 网站建设中最重要的环节是什么企业如何进行宣传和推广
  • 长沙网站设计谷歌浏览器引擎入口
  • 高品质网站设计制作日本免费服务器ip地址
  • 中国室内设计网站官网网站建设详细方案
  • 网站建设分析报告不收费的小说网站排名
  • 教做幼儿菜谱菜的网站百度网站app下载
  • 做全网营销型网站建设网络推广公司企业
  • 通辽市工程建设网站seo有什么作用
  • sem推广软件哪家好网页优化怎么做
  • 深圳专门做网站查找网站
  • 互站网官网北京seo百度推广
  • 网站建设成品超级外链自动发布工具
  • 已备案网站数量百度权重查询爱站网
  • 东莞专业拍摄做网站照片制作网站的最大公司
  • wordpress 登录框seo的概念
  • 电子商务网站建设的好处有哪些软文通
  • 网站建设管理案例实训报告企业营销策划论文
  • 四川住房城乡和城乡建设厅网站百度指数app
  • wordpress自定义图片seo优化教学视频
  • 网页设计作业代做某个网站seo分析实例
  • 做网站模板平台2022搜索引擎
  • 网站开发和优化关系百度竞价排名费用
  • 网站信息管理系统长春关键词优化报价