LeetCode中如何删除排序数组中的重复项
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这篇文章将为大家详细讲解有关LeetCode中如何删除排序数组中的重复项,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一,删除排序数组中的重复项II1
千家信息网最后更新 2025年01月31日LeetCode中如何删除排序数组中的重复项
这篇文章将为大家详细讲解有关LeetCode中如何删除排序数组中的重复项,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
一,删除排序数组中的重复项II
1,问题简述
给定一个增序排列数组 nums ,你需要在 原地 删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以"引用"方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
// nums 是以"引用"方式传递的。也就是说,不对实参做任何拷贝
int len = removeDuplicates(nums);
// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中该长度范围内的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}
2,示例描述
示例 1:
输入:nums = [1,1,1,2,2,3]
输出:5, nums = [1,1,2,2,3]
解释:函数应返回新长度 length = 5, 并且原数组的前五个元素被修改为 1, 1, 2, 2, 3 。你不需要考虑数组中超出新长度后面的元素。
示例 2:
输入:nums = [0,0,1,1,1,1,2,3,3]
输出:7, nums = [0,0,1,1,2,3,3]
解释:函数应返回新长度 length = 7, 并且原数组的前五个元素被修改为 0, 0, 1, 1, 2, 3, 3 。你不需要考虑数组中超出新长度后面的元素。
提示:
0 <= nums.length <= 3 * 104
-104 <= nums[i] <= 104
nums 按递增顺序排列
3,题解思路
根据键值对hashmap进行操作,继续看下下面的程序
4,题解程序
import java.util.*;
public class RemoveDuplicatesTest {
public static void main(String[] args) {
int[] nums = {1, 1, 1, 2, 2, 3};
int removeDuplicates = removeDuplicates(nums);
System.out.println("removeDuplicates = " + removeDuplicates);
}
public static int removeDuplicates(int[] nums) {
if (nums == null || nums.length == 0) {
return 0;
}
Map hashMap = new LinkedHashMap<>();
int index = 0;
for (int i = 0; i < nums.length; i++) {
int value = hashMap.getOrDefault(nums[i], 0) + 1;
hashMap.put(nums[i], value);
if (value <= 2) {
nums[index++] = nums[i];
}
}
return index;
}
}
关于LeetCode中如何删除排序数组中的重复项就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
数组
元素
长度
输入
函数
排序
示例
输出
内容
原地
文章
方式
更多
用者
知识
程序
空间
篇文章
题解
中超
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
王者荣耀能卡服务器么
云服务器hyper-v怎么关
浙江金尚互联网科技有限公司招聘
软件开发公司的优劣势
福建师大网络安全研究生
知了互联网科技有限公司
英国知名网络安全公司排名
iis服务器怎么配置
数据库做阻塞队列
民法典网络安全动态图
解读网络安全知识
怎么取消服务器连接密码
网络安全工程师证件有哪些
涉及网络安全方面的专业
服务器 还是虚拟空间
太原网警检查网络安全
阿里云服务器可以挂两个网站吗
芯片软件开发行业前景
相城区推广网络技术成本
嵌入式软件开发智力玩具总动员
龙之谷找不到登录服务器
云计算软件开发学习
电脑多个网卡的网络安全防护
内蒙古会计软件开发商家
原神手游哪个服务器福利好
廊坊服务器有没有高铁
贵州大学生数据库运维在哪实行
重装系统后税控连接服务器失败
网络安全工程师证件有哪些
没完没了下载软件开发