您现在的位置是:群英 > 开发技术 > web开发
有序数组中的重复值怎么用JS删除
Admin发表于 2022-05-26 17:13:22618 次浏览
这篇文章分享给大家的内容是关于有序数组中的重复值怎么用JS删除,本文介绍得很详细,内容很有参考价值,希望可以帮到有需要的小伙伴,接下来就让小编带领大家一起了解看看吧。

如果有一个有序数组 nums ,要求原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。

不要使用额外的数组空间,必须在 原地 修改输入数组 并在使用 o(1) 额外空间的条件下完成。

说明:

为什么返回数值是整数,但输出的答案是数组呢?

注意:输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。

你可以想象内部操作如下:

// nums 是以“引用”方式传递的。也就是说,不对实参做任何拷贝
int len = removeduplicates(nums);

// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}

示例 1:

输入:nums = [1,1,2]
输出:2, nums = [1,2]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。

示例 2:

输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。

注:

  • ​0 <= nums.length <= 3 * 104​
  • ​-104 <= nums[i] <= 104​
  • ​nums​​ 已按升序排列

思路:

首先,我们知道数组nums是有序的,而且我们只能在原地修改nums数组,不能创建新的数组空间来存储删除重复出现的元素后的结果。

我们需要一边遍历数组查找相同元素,一边在对比发现不同元素时修改数组元素,那么我们可以考虑双指针法的快慢指针了,定义slowfast作为指针;

初始化时指针slow指向数组的起始位置(nums[0]),指针fast指向指针slow的后一个位置(nums[1])。

随着指针fast不断向后移动,将指针fast指向的元素与指针slow指向的元素进行比较:

解:

/**
* @param {number[]} nums
* @return {number}
*/
var removeduplicates = function(nums) {
if(nums.length == 0){return 0;}
let slow = 0, fast = 1;
while(fast < nums.length){
if(nums[fast] != nums[slow]){
slow = slow + 1;
nums[slow] = nums[fast];
}
fast = fast + 1;
}
return slow + 1;
};



关于“有序数组中的重复值怎么用JS删除”的内容就介绍到这,感谢各位的阅读,相信大家对有序数组中的重复值怎么用JS删除已经有了进一步的了解。大家如果还想学习更多知识,欢迎关注群英网络,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2021-12-27 19:02:16 
摘要:这篇文章给大家分享的是C语言字符串的相关内容,主要介绍C语言字符串的输入与输出,以及常用方法。另外,还介绍字符串数组的内容,新手学习和理解C语言字符串有一定帮助,那么感兴趣的朋友接下来一起跟随小编学习一下吧。
2021-12-31 17:56:08 
摘要:Python配置环境变量的操作是什么?我们想要学习和使用Python编程,首先配置Python环境变量是很重要的环节,如果是计算机不熟悉的朋友,对环境变量配置过程还是比较陌生,对此下文给大家分享了详细的操作步骤,需要的朋友可以参考。
2022-06-08 17:44:03 
摘要:下面由golang教程​栏目给大家介绍golang之排序使用,希望对需要的朋友有所帮助!golang标准库实现了许多常用的排序方法,比如对整数序列排序:sort.Ints()...
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部