翼度科技»论坛 编程开发 JavaScript 查看内容

JS算法题解数组删除重复项方法示例

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
题目



删除排序数组中的重复项

给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
示例 1:
  1. 给定数组 nums = [1,1,2],
复制代码
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。
你不需要考虑数组中超出新长度后面的元素。
示例 2:
  1. 给定 nums = [0,0,1,1,1,2,2,3,3,4],
复制代码
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。
你不需要考虑数组中超出新长度后面的元素。

答案


解法1.
  1. const removeDuplicates = nums => {
  2.     let count = 0;
  3.     const n = nums.length;
  4.     for(let i = 1; i < n; i++){
  5.         if(nums[i] != nums[i-1]){
  6.             nums[i-count] = nums[i]
  7.         }else{
  8.             count++;
  9.         }
  10.     }
  11.     return n-count;
  12. };
复制代码
解法2.
  1. const removeDuplicates = nums => {
  2.     let j = 0;
  3.     const n = nums.length;
  4.     for(let i = 1; i < n; i++){
  5.         if(nums[i]!= nums[i-1]){
  6.             j++;
  7.             nums[j] = nums[i];
  8.         }
  9.     }
  10.     return j+1;
  11. };
复制代码
以上就是JS算法题解数组删除重复项方法示例的详细内容,更多关于JS算法数组删除重复项的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/javascript/292155fi9.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具