(lintcode)第452题删除链表中的元素
16lz
2021-04-25
要求:删除链表中等于给定值val的所有节点,样例:给出链表 1->2->3->3->4->5->3
, 和 val = 3
, 你需要返回删除3之后的链表:1->2->4->5
。
代码如下:
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; } * } */public class Solution { /* * @param head: a ListNode * @param val: An integer * @return: a ListNode */ public ListNode removeElements(ListNode head, int val) { // write your code here if(head==null) return head; ListNode p=head,q=head.next; while(q!=null){ if(q.val==val){//保留头结点最后再做判断 p.next=q.next; q=q.next; }else{ p=p.next; q=q.next; } } if(head.val==val)//判断头结点 head=head.next; return head; }}
**此文章仅代表自己(本菜鸟)学习积累记录,或者学习笔记,如有侵权,请联系作者删除。人无完人,文章也一样,文笔稚嫩,在下不才,勿喷,如果有错误之处,还望指出,感激不尽~**
**技术之路不在一时,山高水长,纵使缓慢,驰而不息。**
**公众号:秦怀杂货店**
©著作权归作者所有:来自51CTO博客作者秦怀杂货店的原创作品,如需转载,请注明出处,否则将追究法律责任
更多相关文章
- (lintcode)第6题 合并排序数组
- 图文并茂,带你深入了解AQS的源码
- 二叉树及存储结构
- 技术问答-23 javabean创建一个二叉树,左右两个叶子节点 (1)要求每
- 学习一下小顶堆
- 树与二叉树入门(一)
- 线性表之链式存储(一)
- 9.6 C++指向结构体变量的指针
- 3-8(单链表相关算法习题+双链表)