Remove Duplicates from Sorted List II
2024-08-25 01:50:33
Remove Duplicates from Sorted List II
Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.
For example,
Given 1->2->3->3->4->4->5
, return 1->2->5
.
Given 1->1->1->2->3
, return 2->3
.
分析: 为了便于管理头指针,创建一个新的头指针,利用几个新的变量来判断cur和prev的关系
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* deleteDuplicates(ListNode* head) {
if (head ==NULL)
return head; ListNode* start = new ListNode();
start->next = head; ListNode* cur = head;
ListNode* prev = start;
while(cur){
while(cur->next && cur->next->val == prev->next->val)
cur = cur->next;
if(prev->next == cur)
prev = cur;
else
prev->next = cur->next;
cur = cur->next;
}
return start->next;
}
};
最新文章
- php操作mongodb
- safari浏览器添加书签的方法
- Hadoop源码之HDFS(1)--------通信方式
- Android UI性能优化实战, 识别View中的性能问题
- FPS
- ASP.NET Web API的安全管道
- qsort用法总结
- CSS3教程:pointer-events属性值详解 阻止穿透点击
- Building Xcode iOS projects and creating *.ipa file from the command line
- 关于PKCS5Padding与PKCS7Padding的区别
- wpa_supplicant使用笔记-wpa_cli iwconfig
- MySQL触发器之审计功能(转)
- CodeForces 670 A. Holidays(模拟)
- Spring Boot初探之log4j2配置
- Linux(CentOs6.3)网络配置
- python函数调用的四种方式 --基础重点
- 网络通信协议tcp,udp区别
- Redis基础、应用、第三方支持组件总结
- java中random的几个方法的使用Math.random()和random().
- oozie JAVA Client 编程提交作业
热门文章
- 华硕笔记本U盘启动系统/WinPE报错。Windows failed to start. A Recent hardware or software change might be the cause.
- ASP.NET MVC开发中常见异常及解决方案
- hive 删除分区数据
- 使用javascript生成的植物显示过程特效
- Css动画总结
- jQuery静态方法parseXML使用和源码分析
- iOS 多线程GCD的基本使用
- SharePoint Framework:下一代开发方式
- Java Serializable系列化与反系列化
- <;<;你的灯亮着吗?>;>;读书笔记