leetcode-203 Remove Linked List Elements

原创 2015年07月07日 11:41:00

Remove all elements from a linked list of integers that have value val.

Example
Given: 1 –> 2 –> 6 –> 3 –> 4 –> 5 –> 6, val = 6
Return: 1 –> 2 –> 3 –> 4 –> 5

题意清楚,主要考察链表指针的使用。
小心头结点和尾节点的处理。
时间36ms。
代码:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* removeElements(ListNode* head, int val) {
        if(head == NULL)//空链表
        return head;
        ListNode *p, *q;
        p=q=head;
        while( q!=NULL && q->val == val )//确定头结点
        {
            q=p->next;
            head = p = q;
        }
        if( q == NULL)
        return head;
        q=p->next;
        while( q!=NULL )
        {
            if(q->val == val)//如果出现val
            {
                q=q->next;
            }
            else
            {
                p->next = q;
                p=q;
                q = q->next;
            }
        }
        p->next = q;
        return head;
    }
};
版权声明:本文为博主原创文章,未经博主允许不得转载。

【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

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
  • 3722

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

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

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

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

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

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

【LeetCode-面试算法经典-Java实现】【092-Reverse Linked List II(反转单链表II)】

【092-Reverse Linked List II(反转单链表II)】【LeetCode-面试算法经典-Java实现】【所有题目目录索引】原题  Reverse a linked list fro...
  • DERRANTCM
  • DERRANTCM
  • 2015年08月06日 07:40
  • 1651

面试算法:Linked List-链 表

Linked List-链 表 很多面试相关的书籍都有链表和字符串操作相关的题,这类问题更考验编程基本功和对基础知识的掌握情况。由于之前很多题目做过就忘,再做时总是磕磕绊绊,说明没有真正消化...
  • bobbycho
  • bobbycho
  • 2016年10月23日 20:02
  • 80

C++实现单链表(Singly-Linked List)追加、遍历、删除

#include using namespace std; struct Node { int data; struct Node* next; }; class List { Node* ...
  • wupeak
  • wupeak
  • 2015年01月27日 00:13
  • 646

Leetcode ☞ 203. Remove Linked List Elements ☆ 【dummy 方法二重点掌握】 【方法三双重指针】

给一个单链表和一value,删除掉值等于给定的value的节点,并返回。
  • Dr_Unknown
  • Dr_Unknown
  • 2016年03月08日 14:55
  • 323
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:leetcode-203 Remove Linked List Elements
举报原因:
原因补充:

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