首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    删除链表的倒数第n个节点

    题目: 思路: 由于这是一个链表,所以我们一般只能获取到一个头结点,然而其他信息我们不确定。所以可以采用双指针的方法。...思路一,利用一个指针获取整个链表元素的总数,利用总数减去目标数,所以我们可以确定要删除的位置。...思路二,利用一个指针先走出目标数目,然后两个指针一起走,那么先走的指针走完时,第二个指针恰好会停在目标元素上。...OutPutLinkedList(result);     }     /**      * 方案2,用双指针,一个先走一定的步数,然后一起走,某一个先抵达就停止      *      * @param...+ 1;         //总数减去倒数的数n,就是要遍历的位置了         for (int i = 1; i < index - 1; i++) {             p2 = p2.

    40920

    shell脚本:批量ping N个不连续的IP地址

    序言: Windows系统中批量ping地址时我们长用PingInfoView工具,简单方便实用;而linux中想批量pingIP地址,就得使用脚本了,这里小编和大家分享一个ping脚本。...文件在同一个目录。...ping.sh脚本第4行详解: ps:这边因为-c 3是ping3个包,且不考虑有丢包的情况,也可以直接-c 1,直接ping 1个包。...第6列awk命令提取的值为0 第二种、网络不通,100%丢包。 第6列awk命令提取的值为100 第三种、网络不通,100%丢包,但中间多了2列参数。...第6列awk命令提取的值为+3 综上所述,awk命令第一次使用时取第6列值,且和数值0比较(if=0网络ok,else网络fail),前面两种是没问题,遇到第3种情况:+3是≠0的,满足else条件,网络

    3.6K20

    19 删除链表的倒数第N个节点

    01 题目信息 题目地址: https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list/ 给定一个链表,删除链表的倒数第 n...示例: 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 1->2->3->5. 说明:给定的 n 保证是有效的。...我们第三步删除操作之所以这样分开操作就是因为,我们拿到的是删除节点之前的节点因此删除是头结点的话需要单独处理,这下就不需要了。...它就是我们处理链表的经典方式快慢指针,我们用两个指针,快指针领先n次(倒数次数),慢指针在起点,同时迭代。当快指针到了终点,那慢指针岂不是到了倒数第n个。...fast起点可以取后一格那么slow就能拿到倒数第n个的前一个节点 ?

    33430

    删除链表 M 个节点之后的 N 个节点

    题目 给定链表 head 和两个整数 m 和 n. 遍历该链表并按照如下方式删除节点: 开始时以头节点作为当前节点. 保留以当前节点开始的前 m 个节点. 删除接下来的 n 个节点....输入: head = [1,2,3,4,5,6,7,8,9,10,11,12,13], m = 2, n = 3 输出: [1,2,6,7,11,12] 解析: 保留前(m = 2)个结点, 也就是以黑色节点表示的从链表头结点开始的结点...删除接下来的(n = 3)个结点(3 -> 4 -> 5), 在图中以红色结点表示. 继续相同的操作, 直到链表的末尾. 返回删除结点之后的链表的头结点. 示例 2: ?...输入: head = [1,2,3,4,5,6,7,8,9,10,11], m = 1, n = 3 输出: [1,5,9] 解析: 返回删除结点之后的链表的头结点....[9,3,7,7,9,10,8,2], m = 1, n = 2 输出: [9,7,8] 提示: 1 <= 链表结点数 <= 10^4. [1 的每一个结点值 <=10^6]. 1 <=

    84110

    动图:删除链表的倒数第 N 个结点

    本文主要介绍一道面试中常考链表删除相关的题目,即 leetcode 19. 删除链表的倒数第 N 个结点。采用 双指针 + 动图 的方式进行剖析,供大家参考,希望对大家有所帮助。...删除链表的倒数第 N 个结点 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 进阶:你能尝试使用一趟扫描实现吗? ? ?...题目要求删除 倒数第 n 个 节点,所以首先得找到 该节点的前一节点 ,但由于不知道 整个链表的长度,因此不知道 待删除的节点是正数的第几个节点,所以很难从头节点开始遍历时删除掉这个节点。...思路一 先遍历一遍链表,获取整个链表的长度;假设整个链表的长度为 l,则可知要删除的节点为第 l - n + 1 个节点;再遍历一遍,删除倒数第 n 个节点。...例如链表 L 为 1->2->3->4->5,n = 3,则要删除的节点为 第 5 - 3 + 1 = 3 个节点 。

    32210

    删除链表的倒数第N个节点

    题目描述 给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。 示例: 给定一个链表: 1->2->3->4->5, 和 n = 2....当删除了倒数第二个节点后,链表变为 1->2->3->5. 说明: 给定的 n 保证是有效的。 进阶: 你能尝试使用一趟扫描实现吗?...当A到达null的时候, 指针b的位置正好是倒数n 我们可以设想假设设定了双指针p和q的话,当q指向末尾的NULL,p与q之间相隔的元素个数为n时,那么删除掉p的下一个指针就完成了要求。...设置虚拟节点dummyHead指向head 设定双指针p和q,初始都指向虚拟节点dummyHead 移动q,直到p与q之间相隔的元素个数为n 同时移动p与q,直到q指向的为NULL 将p的下一个节点指向下下个节点...关键点解析 链表这种数据结构的特点和使用 使用双指针 使用一个dummyHead简化操作 代码 /* * @lc app=leetcode id=19 lang=javascript

    29930
    领券