#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) 时间删除链表结点的更多相关文章
-
剑指Offer:面试题13——在O(1)时间删除链表结点
问题描述: 给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间删除该结点.链表结点与函数的定义如下: public class ListNode{ int value; ListNode ...
-
【剑指Offer面试题】 九度OJ1518:反转链表
与其非常快写出一段漏洞百出的代码,倒不如细致分析再写出鲁棒的代码. 提前想好測试用例(输入非空等等)进行測试改动代码. 题目链接地址: http://ac.jobdu.com/problem.php? ...
-
C++版 - 剑指offer 面试题5:从尾到头打印链表 题解
面试题5:从尾到头打印链表 提交网址: http://www.nowcoder.com/practice/d0267f7f55b3412ba93bd35cfa8e8035?tpId=13&tq ...
-
剑指Offer面试题15(Java版):链表中倒数第K个结点
题目: 输入一个链表.输出该链表中倒数第k哥结点. 为了符合大多数人的习惯,本题从1開始计数.即链表的尾结点是倒数第1个结点. 比如一个链表有6个结点.从头结点開始它们的值依次是1.2.3,4,5, ...
-
(剑指Offer)面试题13:在O(1)时间内删除链表结点
题目: 在给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间内删除该结点.链表结点与函数的定义如下: struct ListNode{ int val; ListNode* next; } ...
-
《剑指offer》面试题13 在O(1)时间删除链表节点 Java版
这道题的关键是知道找到尾节点的前一个节点必须遍历,而且这样做了之后总的时间复杂度还是O(1),以及如何不破坏链表删除一个已知节点 public ListNode delete(ListNode hea ...
-
剑指Offer面试题:4.从尾到头打印链表
一.题目:从尾到头打印链表 题目:输入一个链表的头结点,从尾到头反过来打印出每个结点的值. 到解决这个问题肯定要遍历链表.遍历的顺序是从头到尾的顺序,可输出的顺序却是从尾到头.也就是说第一个遍历到的结 ...
-
剑指Offer:面试题17——合并两个排序的链表
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路1: 分别用p1,p2两个指针扫描两个有序链表,p3指针去构建新链表h3. p1.val & ...
-
剑指offer-面试题13.在O(1)时间删除链表节点
题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点. 链表节点与函数的定义如下. 通常我们删除某个节点都是从头开始遍历到需要删除节点的前一个节点. 然后使得该节点的next ...
随机推荐
-
SSL/TLS加密传输与数字证书解读
什么是ssl? secure socket layer(ssl)协议最初由netscape企业发展,现已成为网络用来鉴别网站和网页浏览者身份,以及在浏览器使用者及网页服务器之间进行加密通讯的全球化标准 ...
-
传说中的WeixinJSBridge和微信rest接口
直接上图,金山的APP“微信导航”,从界面上看有粉丝数等关键数据,实现了直接关注功能,莫不是rest接口?这江湖是大佬们的江湖,小喽啰只有眼馋的份咯. 很早就听说过WeixinJSBridge,不过官 ...
-
Sql 行转列问题总结
行转列问题总结 1.行转列 ---1.最简单的行转列/* 问题:假设有张学生成绩表(tb)如下:姓名 课程 分数张三 语文 74张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 物 ...
-
Python模块如何安装 并确认模块已经安装好?
看自己有没有安装好,最简单的办法在可以再控制台下: C:\Users\sony>python Python 2.7.6 (default, Nov 10 2013, 19:24:18) [MSC ...
-
Mongodb备份(mongodump)和恢复(mongorestore)
1.备份: mongodump -d DbName -o /data/backup 2. 恢复: mongorestore -d newDB --drop data/backup/DbName/
-
Duanxx的C++学习 : 数字转换String
下面是这两个数字转换String道路.件:sstream string num2str1(unsigned int num) { stringstream ss; ss<<num; ret ...
-
Sql Server + ADO.NET
MsSql-http://www.cnblogs.com/zhangwei595806165/archive/2012/02/23/2364746.html 协议:Shared Memory :效率最 ...
-
关于tp5自动过滤index.php
在public/.htaccess 中输入这段代码即可实现过滤index.php <IfModule mod_rewrite.c> Options +FollowSymlinks -Mul ...
-
vue中element 的上传功能
element 的上传功能 最近有个需求,需要在上传文件前,可以进行弹窗控制是否上传upload 看完文档后,感觉有两种思路可以实现 基于before-upload :上传文件之前的钩子,参数为上传的 ...
-
RabbitMQ之五种消息模型
首先什么是MQ MQ全称是Message Queue,即消息对列!消息队列是典型的:生产者.消费者模型.生产者不断向消息队列中生产消息,消费者不断的从队列中获取消息.因为消息的生产和消费都是异步的,而 ...