[leetcode][list] Remove Duplicates from Sorted List II

原创 2015年07月07日 11:22:55

题目:

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.

/**
 * 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 (NULL == head || NULL == head->next) return head;
	ListNode *p = head, *tail = NULL;//p指向当前节点,初始化为原链表第一个节点;tail指向新链表的最后一个节点,要初始化为NULL
	head = NULL;//!!!head指向新链表的第一个节点,要初始化为NULL
	while (p != NULL){
		int val = p->val;
		if (p->next == NULL || p->next->val != val){//不是重复节点
			if (NULL == tail){
				tail = p;
				head = p;
			}
			else{
				tail->next = p;//将当前节点连入新链表
				tail = tail->next;//更新tail指针
			}
			p = p->next;//更新当前节点指针
		}
		else {//是重复节点
			while (p != NULL && p->val == val){//删除所有重复节点
				ListNode *tmp = p;
				p = p->next;
				delete tmp;
			}
		}
	}
	if (tail != NULL) tail->next = NULL;//!!!新链表最后一个节点的next为NULL
	return head;
}
};


Remove Duplicates from Sorted List II 移除重复元素和其本身(重重)

题目: 点击打开链接 解答: 设置一个flag标志 代表当前元素是否是重复元素 如果是重复元素 在...
  • skyoceanlover
  • skyoceanlover
  • 2014年08月29日 20:49
  • 282

Remove Duplicates from Sorted List(去除有序链表中的重复元素)

Given a sorted linked list, delete all duplicates such that each element appear only once.(给定一个有序链表,...
  • ajiangfan
  • ajiangfan
  • 2016年10月12日 11:17
  • 247

CareerCup之2.1无序链表删除重复元素

【题目】 原文: 2.1 Write code to remove duplicates from an unsorted linked list. FOLLOW UP H...
  • SunnyYoona
  • SunnyYoona
  • 2014年05月18日 17:08
  • 1933

遍历List 同时 remove 元素

List list = new ArrayList(); list.add(1); list.add(2); list.add(3); list.add(4); list.add(...
  • Vestigge
  • Vestigge
  • 2013年01月21日 14:22
  • 3718

基于C++ list中erase与remove函数的使用详解

erase的作用是,使作为参数的迭代器失效,并返回指向该迭代器下一参数的迭代器。 如下: 复制代码代码如下: list ParticleSystem; list::iter...
  • wujin8589
  • wujin8589
  • 2016年07月21日 08:16
  • 244

【LeetCode-面试算法经典-Java实现】【019-Remove Nth Node From End of List(移除单链表的倒数第N个节点)】

【019-Remove Nth Node From End of List(移除单链表的倒数第N个节点)】【LeetCode-面试算法经典-Java实现】【所有题目目录索引】原题  Given a l...
  • DERRANTCM
  • DERRANTCM
  • 2015年07月22日 07:24
  • 2058

Java list.remove( )方法需要注意的两个地方

list.remove最近做项目的过程中,需要用到list.remove()方法,结果发现两个有趣的坑,经过分析后找到原因,记录一下跟大家分享一下。代码直接上一段代码,进行分析。public clas...
  • DeMonliuhui
  • DeMonliuhui
  • 2017年07月13日 14:41
  • 2208

Java list.remove( )方法需要注意的两个地方

public class Main { public static void main(String[] args) { List stringList = new Arra...
  • anmoyyh
  • anmoyyh
  • 2017年07月24日 14:03
  • 654

在for循环中remove list报错越界的问题

最近在搞一个购物车的功能,里面有一个批量删除的操作,采用的是ExpandableListView以及BaseExpandableListAdapter。视乎跟本篇无关紧要,主要是为了记录一个java基...
  • z_zT_T
  • z_zT_T
  • 2017年04月18日 15:22
  • 756

Remove Duplicates from Sorted Array——移除排序数组中重复元素

Remove Duplicates from Sorted Array Given a sorted array, remove the duplicates in place such tha...
  • suibianshen2012
  • suibianshen2012
  • 2016年08月17日 23:09
  • 241
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[leetcode][list] Remove Duplicates from Sorted List II
举报原因:
原因补充:

(最多只允许输入30个字)