#include <iostream>
using namespace std; //构造链表结点
struct ListNode
{
int val;
ListNode *next; ListNode(int v = ):val(v), next(NULL){};
}; //打印结点
void printList(ListNode *head)
{
while(head != NULL)
{
cout<<head->val<<" ";
head = head->next;
}
cout<<endl;
} //删除结点
void deleteListNode(ListNode **head, ListNode *tobeDeleted)
{
//头结点或者待删除结点为空,则结束调用
if(*head == NULL || tobeDeleted == NULL)
return ; //待删除结点的pnext非空,则复制其值到待删除结点,删除pnext
if(tobeDeleted->next != NULL)
{
ListNode *pnext = tobeDeleted->next; tobeDeleted->val = pnext->val;
tobeDeleted->next = pnext->next; delete pnext;
pnext = NULL;
}
//若只剩头结点,则删除头结点
else if(tobeDeleted == *head)
{
delete tobeDeleted; tobeDeleted = NULL;
*head = NULL;
}
//若待删除结点为尾结点,则顺序查找后删除
else
{
ListNode *phead = *head; while(phead->next != tobeDeleted)
{
phead = phead->next;
} phead->next = NULL;
delete tobeDeleted;
tobeDeleted = NULL;
}
} int main()
{
ListNode *ls = new ListNode();
ListNode *head = ls; ListNode *l1 = new ListNode();
ls->next = l1;
ls = ls->next; ListNode *l2 = new ListNode();
ls->next = l2;
ls = ls->next; ListNode *l3 = new ListNode();
ls->next = l3;
ls = ls->next; ListNode *l4 = new ListNode();
ls->next = l4;
ls = ls->next; cout<<"初始链表 -> ";
printList(head);
cout<<endl; cout<<"删除中间结点2后 -> ";
deleteListNode(&head,l2);
printList(head);
cout<<endl; cout<<"删除尾结点4后 -> ";
deleteListNode(&head,l4);
printList(head);
cout<<endl; cout<<"删除中间结点1后 -> ";
deleteListNode(&head,l1);
printList(head);
cout<<endl; cout<<"删除尾结点3后 -> ";
deleteListNode(&head,l1);
printList(head);
cout<<endl; cout<<"删除头结点后 -> ";
deleteListNode(&head,head);
printList(head);
cout<<endl;
}

测试结果:

初始链表 ->     

删除中间结点2后 ->    

删除尾结点4后 ->   

删除中间结点1后 ->  

删除尾结点3后 -> 

删除头结点后 ->

【剑指offer 面试题13】在 O(1) 时间删除链表结点的更多相关文章

  1. 剑指Offer:面试题13——在O(1)时间删除链表结点

    问题描述: 给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间删除该结点.链表结点与函数的定义如下: public class ListNode{ int value; ListNode ...

  2. 【剑指Offer面试题】 九度OJ1518:反转链表

    与其非常快写出一段漏洞百出的代码,倒不如细致分析再写出鲁棒的代码. 提前想好測试用例(输入非空等等)进行測试改动代码. 题目链接地址: http://ac.jobdu.com/problem.php? ...

  3. C++版 - 剑指offer 面试题5:从尾到头打印链表 题解

    面试题5:从尾到头打印链表 提交网址: http://www.nowcoder.com/practice/d0267f7f55b3412ba93bd35cfa8e8035?tpId=13&tq ...

  4. 剑指Offer面试题15(Java版):链表中倒数第K个结点

    题目: 输入一个链表.输出该链表中倒数第k哥结点.  为了符合大多数人的习惯,本题从1開始计数.即链表的尾结点是倒数第1个结点. 比如一个链表有6个结点.从头结点開始它们的值依次是1.2.3,4,5, ...

  5. (剑指Offer)面试题13:在O(1)时间内删除链表结点

    题目: 在给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间内删除该结点.链表结点与函数的定义如下: struct ListNode{ int val; ListNode* next; } ...

  6. 《剑指offer》面试题13 在O(1)时间删除链表节点 Java版

    这道题的关键是知道找到尾节点的前一个节点必须遍历,而且这样做了之后总的时间复杂度还是O(1),以及如何不破坏链表删除一个已知节点 public ListNode delete(ListNode hea ...

  7. 剑指Offer面试题:4.从尾到头打印链表

    一.题目:从尾到头打印链表 题目:输入一个链表的头结点,从尾到头反过来打印出每个结点的值. 到解决这个问题肯定要遍历链表.遍历的顺序是从头到尾的顺序,可输出的顺序却是从尾到头.也就是说第一个遍历到的结 ...

  8. 剑指Offer:面试题17——合并两个排序的链表

    题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路1: 分别用p1,p2两个指针扫描两个有序链表,p3指针去构建新链表h3. p1.val & ...

  9. 剑指offer-面试题13.在O(1)时间删除链表节点

    题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点. 链表节点与函数的定义如下. 通常我们删除某个节点都是从头开始遍历到需要删除节点的前一个节点. 然后使得该节点的next ...

随机推荐

  1. Java学习笔记(二)UML基础

    用例图:代表系统的一个功能模块,仅仅是系统功能的描述.用例图包括:用例.角色.角色和用例之间的关系以及系统内用例之间的关系. 类图:表示系统中包含哪些实体,各实体之间如何关联. 类图除了表示实体内部结 ...

  2. 【零基础学习iOS开发】【02-C语言】05-进制

    上一讲简单介绍了常量和变量,这讲补充一点计算机的基础知识---进制. 我们先来看看平时是如何表示一个整数的,最常见的肯定是用阿拉伯数字表示,比如“十二”,我们可以用12来表示,其实这种表示方式是基于一 ...

  3. 李洪强iOS开发之Foundation框架—集合

    Foundation框架—集合 一.NSArray和NSMutableArray (一)NSArray不可变数组 (1)NSArray的基本介绍 NSArray是OC中使用的数组,是面向对象的,以面向 ...

  4. unity3d泰斗破坏神2----课程列表

    免费 课时1:泰斗破坏神第一支预告视频 01:32免费 课时2:泰斗破坏神第二支预告视频 01:58第 1 章 : 游戏开始 用户登录 服务器选择课时3:游戏开始 用户登录 服务器选择课时4:素材介绍 ...

  5. SpringAOP拦截Controller,Service实现日志管理(自定义注解的方式)

    转载:http://itindex.net/detail/50710-springaop-controller-service 从业近二,三年了,第一次写博客,平时做做脚手架或者架构一些基础框架然后给 ...

  6. Jdk命令之jps

    jps -- Java Virtual Machine Process Status Tool jps命令类似于Linux下的ps命令,可以列出本机所有正在运行的java进程.

  7. centos下安装JDK8的方法

    判断是否安装 首先,我们得判断机子上是不是安装了jdk,好多人推荐使用java -version命令.我的计算机上使用java -version命令,内容如下: java version " ...

  8. C# 使用ManualResetEvent 进行线程同步

    上一篇我们介绍了AutoResetEvent,这一篇我们来看下ManualResetEvent ,顾名思义ManualResetEvent  为手动重置事件. AutoResetEvent和Manua ...

  9. MySQL 5.7 SYS scheme解析

    sys 库是MySQL 5.7其中的一个系统库,里面有很多很好用的跟性能相关的视图.函数和存储过程, 增强MySQL的易用性 例如:哪些语句使用了临时表,哪个用户请求了最多的io,哪个线程占用了最多的 ...

  10. S5P4418iNand清空方法

    01连接串口线 02打开Fastboot的Xshell串口插件 03启动开发板 04一启动就输入回车键 05在uboot处停住,输入:mmc erase blk 10000 (mmc erase bo ...