删除链表中重复的结点
2016-06-30 11:52
405 查看
题目描述
在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5解法一:递归
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}
*/
public class Solution {
public ListNode deleteDuplication(ListNode pHead)
{
if(pHead == null || pHead.next == null) {
return pHead;
}
if(pHead.next.val == pHead.val) {
ListNode curNode = pHead.next.next;
int val = pHead.val;
while(curNode != null && curNode.val == val) {
curNode = curNode.next;
}
return deleteDuplication(curNode);
} else {
pHead.next = deleteDuplication(pHead.next);
return pHead;
}
}
}
解法二:非递归
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}
*/
public class Solution {
public ListNode deleteDuplication(ListNode pHead)
{
if(pHead == null || pHead.next == null) {
return pHead;
}
ListNode root = new ListNode(0);
root.next = pHead;//头结点前驱结点
ListNode pre = root;//pre为移动当前节点的前驱节点
ListNode cur = pHead;//当前节点
while(cur != null && cur.next != null) {
//当前节点与下一个节点值相等
if(cur.next.val == cur.val) {
while(cur.next != null && cur.next.val == cur.val) {
cur = cur.next;
}
//pre不需后移,因为node.next也可能是重复的
pre.next = cur.next;
}
//当前节点与下一节点
else {
pre.next = cur;
pre = pre.next;
}
cur = cur.next;
}
return root.next;
}
}
相关文章推荐
- 详解MathType中如何批量修改公式字体和大小
- gdb查看线程堆栈信息
- Kernel panic - not syncing: No init found. Try passing init= option to kernel. See Linux ...
- vmware虚拟机系统esxi不能识别不兼容网卡解决方案
- curl php
- springmvc拦截器实现登陆认证
- 刷新
- Speech WINPE中TTS语音引擎所需文件
- 《剑指offer》-04重建二叉树
- webpack使用
- iphone手机浏览器文本框不触发输入中文的keyup事件
- Swift tour
- 2050折线分割平面(简单递推)(折线切分平面)
- hibernate主键的生成器
- win7宽带无法创建 711错误
- 面向对象的基本知识
- Linux基础命令之SS
- Elasticsearch java API (14)Search API Terminate After 终止后
- 关于nginx配置成功后,无法访问的问题
- 七 APPIUM Android 定位方式