1. 题目

实现一种算法,删除单向链表中间的某个节点(除了第一个和最后一个节点,不一定是中间节点),假定你只能访问该节点。

示例:
输入:单向链表a->b->c->d->e->f中的节点c
结果:不返回任何数据,但该链表变为a->b->d->e->f

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-middle-node-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 只有被删除的节点,无法获取其前置节点
  • 交换要删除的节点和其下一个节点的val
  • 然后要删除的值的前一个节点就知道了
class Solution {public:void deleteNode(ListNode* node) {swap(node->val, node->next->val);node->next = node->next->next;}
};

程序员面试金典 - 面试题 02.03. 删除中间节点相关推荐

  1. 程序员面试金典 - 面试题 04.03. 特定深度节点链表(BFS)

    1. 题目 给定一棵二叉树,设计一个算法,创建含有某一深度上所有节点的链表(比如,若一棵树的深度为 D,则会创建出 D 个链表).返回一个包含所有深度的链表的数组. 例: 输入:[1,2,3,4,5, ...

  2. 程序员面试金典 - 面试题 10.03. 搜索旋转数组

    题目难度: 中等 原题链接 今天继续更新程序员面试金典系列, 大家在公众号 算法精选 里回复 面试金典 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 搜索旋转数组.给定一个排序后的数组 ...

  3. 程序员面试金典 - 面试题 05.03. 翻转数位(位运算)

    1. 题目 给定一个32位整数 num,你可以将一个数位从0变为1.请编写一个程序,找出你能够获得的最长的一串1的长度. 示例 1: 输入: num = 1775(11011101111) 输出: 8 ...

  4. 程序员面试金典 - 面试题 02.04. 分割链表

    1. 题目 编写程序以 x 为基准分割链表,使得所有小于 x 的节点排在大于或等于 x 的节点之前.如果链表中包含 x,x 只需出现在小于 x 的元素之后(如下所示).分割元素 x 只需处于" ...

  5. [Leetcode][程序员面试金典][面试题08.03][JAVA][魔术索引][递归][优化]

    [问题描述][简单] [解答思路] 1. 逐个查找 时间复杂度:O(N) 空间复杂度:O(1) public int findMagicIndex(int[] nums) {for (int i = ...

  6. 程序员面试金典 - 面试题 16.03. 交点(数学)

    1. 题目 给定两条线段(表示为起点start = {X1, Y1}和终点end = {X2, Y2}),如果它们有交点,请计算其交点,没有交点则返回空值. 要求浮点型误差不超过10^-6.若有多个交 ...

  7. 程序员面试金典 - 面试题 10.03. 搜索旋转数组(二分查找)

    1. 题目 搜索旋转数组.给定一个排序后的数组,包含n个整数,但这个数组已被旋转过很多次了,次数不详. 请编写代码找出数组中的某个元素,假设数组元素原先是按升序排列的.若有多个相同元素,返回索引值最小 ...

  8. 程序员面试金典 - 面试题 08.03. 魔术索引(二分递归)

    1. 题目 魔术索引. 在数组A[0-n-1]中,有所谓的魔术索引,满足条件A[i] = i. 给定一个有序整数数组,编写一种方法找出魔术索引,若有的话,在数组A中找出一个魔术索引,如果没有,则返回- ...

  9. 程序员面试金典 - 面试题 02.05. 链表求和

    1. 题目 给定两个用链表表示的整数,每个节点包含一个数位. 这些数位是反向存放的,也就是个位排在链表首部. 编写函数对这两个整数求和,并用链表形式返回结果. 示例: 输入:(7 -> 1 -& ...

最新文章

  1. pmp考试用计算机,PMP是计算机类考试吗
  2. 浅析C# new和override的区别
  3. python换循环颜色_python – 增加matplotlib颜色循环
  4. lua pcall 返回值_Redis和Lua整合
  5. 架构设计 | 缓存管理模式,监控和内存回收策略
  6. @Override错误
  7. cad通过钢筋大样生成钢筋明细表插件_为什么自动生成的钢筋明细表为空 - 应用技巧 - 常青藤软件工作室...
  8. Abp Quartz配置Sqlite
  9. 明解C语言(入门篇)第十章
  10. 【软考】--软考是一盘散沙?NO
  11. 浏览器如何工作~(转)
  12. 谷歌浏览器崩溃!亲测有效
  13. 接入Apple Pay流程
  14. 动态规划法(二)——弗洛伊德算法
  15. tbook10s换linux,【台电Tbook10s使用测试】硬件配置|驱动适配|续航_摘要频道_什么值得买...
  16. 搭建电话机器人或OKCC外呼中心系统实体机与云服务器哪个好(三)
  17. 电子货架标签------一种新用法(手机APP直接操作)
  18. FST工控软件平台解读
  19. N76E003中断设置流程
  20. OneFlow深度学习框架介绍

热门文章

  1. python pip本地安装包_python-pip install 安装包
  2. mac显示无法连接adobe服务器,Mac安装Adobe软件,如遇Error提示解决方法
  3. uboot移植——DM9000的移植
  4. 将区块链哈希转化为文字标题?IPSE哈希技术Hashlink解释
  5. web前端细解cookie那些事
  6. 动态规划:树形DP-景点中心(树的带权重心)
  7. P4555 最长双回文串
  8. ASP.NET获取路径的方法
  9. css 相对定位与绝对定位
  10. WCF X.509验证