博客
关于我
牛客题霸 [删除链表的倒数第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/

你可能感兴趣的文章
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
network小学习
查看>>
Netwox网络工具使用详解
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
Net操作配置文件(Web.config|App.config)通用类
查看>>
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
New Relic——手机应用app开发达人的福利立即就到啦!
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>