博客
关于我
牛客题霸 [删除链表的倒数第n个节点] C++题解/答案
阅读量:124 次
发布时间:2019-02-27

本文共 929 字,大约阅读时间需要 3 分钟。

题目描述

给定一个链表,删除链表的倒数第n个节点并返回链表的头指针

例如,
给出的链表为:1->2->3->4->5, n= 2.
删除了链表的倒数第n个节点之后,链表变为1->2->3->5.
备注:
题目保证n一定是有效的
请给出请给出时间复杂度为O(n)的算法

题解:

有个小技巧,叫什么名字我也不知道

如果你想让a到达倒数第n个节点,可以先复制一个b和a一样,然后b先跑n个节点,然后b和a再一起跑,当b跑到头时,a正好就在倒数第n个节点上,仔细考虑考虑这是为什么?
然后a->next=a->next->next;
就是直接越过第n个节点,让第n-1个与n+1个链接起来

代码:

/** * struct ListNode { *	int val; *	struct ListNode *next; * }; */class Solution {   public:    /**     *      * @param head ListNode类      * @param n int整型      * @return ListNode类     */    ListNode* removeNthFromEnd(ListNode* head, int n) {           // write code here        if(!head)return head;        ListNode* a=new ListNode(0);        a->next=head;        ListNode* pre=a;        ListNode* p=a;        for(int i=1;i<=n;i++)        {               pre=pre->next;        }        while(pre->next)        {               pre=pre->next;            p=p->next;        }        p->next=p->next->next;        return a->next;    }};

转载地址:http://kbzb.baihongyu.com/

你可能感兴趣的文章
vue3+Ts 项目打包时报错 ‘reactive‘is declared but its value is never read.及解决方法
查看>>
Node-RED中Switch开关和Dropdown选择组件的使用
查看>>
Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-random节点来实现随机数在折线图中显示
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用node-red-contrib-image-output节点实现图片预览
查看>>
Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
查看>>
Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
查看>>
Node-RED中使用range范围节点实现从一个范围对应至另一个范围
查看>>
Node-RED中实现HTML表单提交和获取提交的内容
查看>>
Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
查看>>
Node-RED中建立TCP服务端和客户端
查看>>
Node-RED中建立Websocket客户端连接
查看>>
Node-RED中建立静态网页和动态网页内容
查看>>
Node-RED中解析高德地图天气api的json数据显示天气仪表盘
查看>>
Node-RED中连接Mysql数据库并实现增删改查的操作
查看>>
Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
查看>>
Node-RED中配置周期性执行、指定时间阶段执行、指定时间执行事件
查看>>