首页
题库
面试
求职
学习
竞赛
More+
所有博客
搜索面经/职位/试题/公司
搜索
我要招人
去企业版
登录 / 注册
首页
>
试题广场
>
删除有序链表中重复的元素-I
[编程题]删除有序链表中重复的元素-I
热度指数:178574
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 256M,其他语言512M
算法知识视频讲解
删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次
例如:
给出的链表为
,返回
.
给出的链表为
,返回
.
数据范围:链表长度满足
,链表中任意节点的值满足
进阶:空间复杂度
,时间复杂度
示例1
输入
{1,1,2}
输出
{1,2}
示例2
输入
{}
输出
{}
说明:本题目包含复杂数据结构ListNode,
点此查看相关信息
马上挑战
算法知识视频讲解
提交运行
算法知识视频讲解
添加笔记
求解答(0)
邀请回答
收藏(424)
分享
提交结果有问题?
383个回答
397篇题解
开通博客
牛客题解官
发表于 2022-04-22 11:36:29
精华题解
题目主要信息: 给定一个从小到大排好序的链表 删去链表中重复的元素,每个值只留下一个节点 举一反三: 学习完本题的思路你可以解决如下题目: BM16. 删除有序链表中重复的元素-II 方法:遍历删除(推荐使用) 思路: 既然连续相同的元素只留下一个,我们留下哪一个最好呢?当然是遇到的第一个元素了
展开全文
牛一霸
发表于 2021-07-06 23:07:56
精华题解
题目:删除有序链表中重复的元素 描述:删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次 例如:给出的链表为1→1→2,返回1→2. 给出的链表为1→1→2→3→3,返回1→2→3. 示例1:输入:{1,1,2},返回值:{1,2} 解法一:
展开全文
鸠摩罗什
发表于 2021-07-11 12:58:10
精华题解
描述 删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次例如:给出的链表为1→1→2,返回1→2.给出的链表为1→1→2→3→3,返回1→2→3.示例1输入:{1,1,2}返
展开全文
冰箱的主人LR
发表于 2021-07-16 22:54:26
精华题解
牛客NC25#删除有序链表中重复的元素-I# 题目链接 描述 删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次例如:给出的链表为1→1→2,返回1→2.给出的链表为1→1→2→3→3,返回1→2→3. 题目很简单,因为给的是升序链表相同的都挨在一起,所以我们确定链表
展开全文
蒙牛麦片
发表于 2021-07-16 17:43:56
精华题解
NC25 删除有序链表中重复的元素-I 题意分析: 给一个有序的链表,删除其中的重复的元素。 题解一(遍历): 我们初始化两个指针,指针flag指向当前编制元素,代表有其他指针的值与其相同的标志点。设置指针p,用于遍历链表。 当flag==p时候,p指向其下一个元素 当flag!=p时候,我们需
展开全文
卫宫士郎红A
发表于 2020-07-17 16:40:26
题目描述删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次 例如: 给出的链表为1->1->2,返回1->2. 给出的链表为1->1->2->3->3,返回1->2->3. Given a sorted li
展开全文
西山第一提莫
发表于 2022-02-26 12:25:22
```import java.util.*; /* * public class ListNode { * int val; * ListNode next = null; * } */ public class Solution { /** *
展开全文
进阶的小菜鸡🐔
发表于 2022-08-18 13:49:05
struct ListNode* deleteDuplicates(struct ListNode* head) { if(head == NULL) &n
展开全文
mjzCheerup
发表于 2022-04-11 15:33:05
* struct ListNode { * int val; * struct ListNode *next; * }; */ class Solution { public: /** * * @param head ListNode类 * @re
展开全文
去种田的程序员
发表于 2020-06-01 15:20:54
题目描述:删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次 例如: 给出的链表为1->1->2,返回1->2. 给出的链表为1->1->2->3->3,返回1->2->3. 个人
展开全文
程序员学长
发表于 2021-11-02 14:11:28
更多题解,请关注公众号:程序员学长,让你进大厂不走弯路 删除有序链表中重复的元素-I 问题描述 LeetCode 83. 删除排序链表中的重复元素 删除给出链表中的重复元素(链表中元素从小到大有序),使链表中的所有元素都只出现一次。 示例: 输入:{1,1,2} 输出:{1,2} 分析问题 因为给定
展开全文
三木orz
发表于 2022-03-04 17:53:33
双指针,flag标记唯一数,cur标记当前位 class Solution { public: ListNode* deleteDuplicates(ListNode* head) { if(!head) return head; // write code
展开全文
牛客495668876号
发表于 2022-08-19 23:01:42
/* * function ListNode(x){ * this.val = x; * this.next = null; * } */ /** *
展开全文
KEY.L
发表于 2022-07-02 19:44:15
* struct ListNode { * int val; * struct ListNode *next; * }; */ class Solution&
展开全文
ETO-ccc
发表于 2023-03-04 13:35:50
/** * struct ListNode { * int val; * struct ListNode *next; * }; */ class Solution { public: /** * * @param head ListNode类
展开全文
问题信息
链表
难度:
383条回答
424收藏
27796浏览
热门推荐
通过挑战的用户
查看代码
随机昵称都有什...
2023-02-17 11:10:24
躺平的程序员
2022-10-24 16:13:01
不摆烂不会摆烂
2022-09-22 11:14:29
牛客352138号
2022-09-19 21:20:13
牛客57846...
2022-09-17 09:23:55
相关试题
编程题 ,按照要求创建Java 应...
Java
评论
(1)
3.1996至2003年间,从事高...
资料分析
言语理解与表达
资料分析
评论
(1)
电路板布线的时候尽量采用( )折线布线
PCB
评论
(1)
市场与销售的区别在哪里?
市场营销
评论
(1)
图中U和I分别为
电路基础
评论
(1)
删除有序链表中重复的元素-I
扫描二维码,关注牛客网
意见反馈
下载牛客APP,随时随地刷题
import java.util.*; /* * public class ListNode { * int val; * ListNode next = null; * public ListNode(int val) { * this.val = val; * } * } */ public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ public ListNode deleteDuplicates (ListNode head) { // write code here } }
/** * struct ListNode { * int val; * struct ListNode *next; * ListNode(int x) : val(x), next(nullptr) {} * }; */ class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ ListNode* deleteDuplicates(ListNode* head) { // write code here } };
#coding:utf-8 # class ListNode: # def __init__(self, x): # self.val = x # self.next = None # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # # @param head ListNode类 # @return ListNode类 # class Solution: def deleteDuplicates(self , head ): # write code here
using System; using System.Collections.Generic; /* public class ListNode { public int val; public ListNode next; public ListNode (int x) { val = x; } } */ class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ public ListNode deleteDuplicates (ListNode head) { // write code here } }
/* * function ListNode(x){ * this.val = x; * this.next = null; * } */ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ function deleteDuplicates( head ) { // write code here } module.exports = { deleteDuplicates : deleteDuplicates };
val = $x; } }*/ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ function deleteDuplicates( $head ) { // write code here }
# class ListNode: # def __init__(self, x): # self.val = x # self.next = None # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # # @param head ListNode类 # @return ListNode类 # class Solution: def deleteDuplicates(self , head: ListNode) -> ListNode: # write code here
package main import "fmt" import . "nc_tools" /* * type ListNode struct{ * Val int * Next *ListNode * } */ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ func deleteDuplicates( head *ListNode ) *ListNode { // write code here }
/** * struct ListNode { * int val; * struct ListNode *next; * }; */ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ struct ListNode* deleteDuplicates(struct ListNode* head ) { // write code here }
# class ListNode # attr_accessor :val, :next # # def initialize(val = 0, _next = nil) # @val, @next = val, _next # end # end # # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # # @param head ListNode类 # @return ListNode类 # class Solution def deleteDuplicates(head) # write code here end end
/** * class ListNode(var val: Int) { * var next: ListNode = null * } */ object Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ def deleteDuplicates(head: ListNode): ListNode = { // write code here } }
/** * class ListNode(var `val`: Int) { * var next: ListNode? = null * } */ object Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ fun deleteDuplicates(head: ListNode?): ListNode? { // write code here } }
import java.util.*; /* * public class ListNode { * int val; * ListNode next = null; * public ListNode(int val) { * this.val = val; * } * } */ public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ public ListNode deleteDuplicates (ListNode head) { // write code here } }
/*class ListNode { * val: number * next: ListNode | null * constructor(val?: number, next?: ListNode | null) { * this.val = (val===undefined ? 0 : val) * this.next = (next===undefined ? null : next) * } * } */ /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ export function deleteDuplicates(head: ListNode): ListNode { // write code here }
/** * public class ListNode { * public var val: Int * public var next: ListNode? * public init(_ val: Int = 0, _ next: ListNode? = nil) { * self.val = val * self.next = next * } * } */ public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ func deleteDuplicates ( _ head: ListNode?) -> ListNode? { // write code here } }
/** * #[derive(PartialEq, Eq, Debug, Clone)] * pub struct ListNode { * pub val: i32, * pub next: Option
> * } * * impl ListNode { * #[inline] * fn new(val: i32) -> Self { * ListNode { * val: val, * next: None, * } * } * } */ struct Solution{ } impl Solution { fn new() -> Self { Solution{} } /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @return ListNode类 */ pub fn deleteDuplicates(&self, head: Option
>) -> Option
> { // write code here } }
{1,1,2}
{1,2}
{}
{}