您的位置:首页 > Web前端

剑指offer——删除链表中重复的结点

2016-06-26 23:58 330 查看

题目描述:

在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表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) return pHead;
ListNode firstNode = new ListNode(-1);
firstNode.next = pHead;
ListNode preNode = firstNode;
ListNode curNode = pHead;
while(curNode != null && curNode.next != null){
if(curNode.val == curNode.next.val){
int val = curNode.val;
while(curNode != null && curNode.val == val){
curNode = curNode.next;
}
preNode.next = curNode;
}else{
preNode = curNode;
curNode = curNode.next;
}
}
return firstNode.next;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: