一、题目

给定一个排序数组,在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。

不要使用额外的数组空间,必须在原地修改输入数组,并使用 O(1) 额外空间来修改输入的数组。

示例1:

给定数组 nums = [1,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。

你不需要考虑数组中超出新长度后面的元素。

第一个示例中,函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。

第二个示例中,函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。

这里不需要考虑数组中超出新长度后面的元素。

二、题解

  • 首先,题目规定了空间复杂度是O(1),对时间复杂度没做要求,当然了,我们解题还是要追求一下更小的时间复杂度,能O(n)就不O(n²),能O(logn)就不O(n)。

  • 其次,题目给出数组已经排好序了,当数组为空或只有1个元素时,肯定没有重复项,直接返回数组长度即可;只有当数组中的元素大于3个,才可能出现重复项。

  • 第三,要修改给定的数组,而不是返回一个新数组,我想到了PHP中的“引用传递”,修改数组中的某个元素,整个数组也会变化。

我首先想到的做法是:遍历数组,将当前元素和下一个元素进行比较,如果相同,就删除当前元素,直到遍历到末尾。代码如下:

function removeDuplicates(&$nums) {
if (count($nums) <= 2) {
return count($nums);
} for ($i = 0; $i < count($nums) - 1; $i++) {
if ($nums[$i] == $nums[$i + 1]) {
unset($nums[$i]);
}
echo count($nums) . "<br>";
}
return count($nums);
}

提交代码未通过。输入的是[0,0,1,1,1,2,2,3,3,4],可输出的是[0,1,2,3,3,4],并没有完成去重。琢磨了一下代码,发现漏洞:既然是引用传递,每 unset 一个元素,都会改变数组的长度,而随着数组长度的缩短,遍历次数也会跟着改变(减少),后面的元素就不再进行比较、删除了。

那就记录遍历时遇到的重复元素,使用两个指针,一快一慢指针,慢指针 i 记录不重复元素,快指针 j 遍历数组,当(nums[i] != nums[j])时,将慢指针右移一位,同时将快指针指向的元素赋值给当前慢指针;当两者相等时则跳过,即双指针法

function removeDuplicates(&$nums) {
if (count($nums) <= 1) {
return count($nums);
} $i = 0;
for ($j = 1; $j < count($nums); $j++) {
if ($nums[$i] == $nums[$j]) {
continue;
}
$i++;
$nums[$i] = $nums[$j];
}
return count(array_slice($nums, 0, $i + 1));
}

LeetCode#26 | Remove Duplicates from Sorted Array 删除有序数组中的重复元素的更多相关文章

  1. 26. Remove Duplicates from Sorted Array(删除排序数组中的重复元素,利用排序的特性,比较大小)

      Given a sorted array, remove the duplicates in-place such that each element appear only once and r ...

  2. [LeetCode]26. Remove Duplicates from Sorted Array删除排序数组中的重复项

    Given a sorted array nums, remove the duplicates in-place such that each element appear only once an ...

  3. [LeetCode] 80. Remove Duplicates from Sorted Array II 有序数组中去除重复项 II

    Given a sorted array nums, remove the duplicates in-place such that duplicates appeared at most twic ...

  4. [LeetCode] 26. Remove Duplicates from Sorted Array ☆(从有序数组中删除重复项)

    [LeetCode] Remove Duplicates from Sorted Array 有序数组中去除重复项 描述 Given a sorted array nums, remove the d ...

  5. [LeetCode] 80. Remove Duplicates from Sorted Array II 有序数组中去除重复项之二

    Given a sorted array nums, remove the duplicates in-place such that duplicates appeared at most twic ...

  6. 【LeetCode】Remove Duplicates from Sorted Array(删除排序数组中的重复项)

    这道题是LeetCode里的第26道题. 题目描述: 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入数 ...

  7. [LeetCode] Remove Duplicates from Sorted Array II 有序数组中去除重复项之二

    Follow up for "Remove Duplicates":What if duplicates are allowed at most twice? For exampl ...

  8. lintcode :Remove Duplicates from Sorted Array 删除排序数组中的重复数字

    题目: 删除排序数组中的重复数字 给定一个排序数组,在原数组中删除重复出现的数字,使得每个元素只出现一次,并且返回新的数组的长度. 不要使用额外的数组空间,必须在原地没有额外空间的条件下完成.  样例 ...

  9. 【LeetCode】Remove Duplicates from Sorted List(删除排序链表中的重复元素)

    这道题是LeetCode里的第83道题. 题目描述: 给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次. 示例 1: 输入: 1->1->2 输出: 1->2 示例 2: ...

随机推荐

  1. Arrays.asList 返回值类型

    public static void main(String[] args) { Integer[] datas = {1,2,3,4,5}; List<Integer> list = A ...

  2. java接入钉钉机器人(带源码)

    前言 登录钉钉网页: https://im.dingtalk.com 登录说明文档地址,以备随时查询: https://ding-doc.dingtalk.com/doc#/serverapi2/qf ...

  3. TensorFlow——tensorflow编程基础

    0.tensorflow中的模型运行基础 tensorflow的运行机制属于定义和运行相分离,在操作层面可以抽象成两种:模型构建和模型运行. 在模型构建中的常见概念: 张量(tensor):数据,即某 ...

  4. Jaeger容器化部署

    概述 Jaeger是由Uber开源的分布式追踪系统,一套完整的Jager追踪系统包括Jaeger-client.Jaeger-agent.Jaeger-collector.Database和Jaege ...

  5. Java 集合的工具类Collections的常用方法

    Collections类 java.utils.Collections是集合工具类,用来对集合进行操作. Collections类的常用方法 这里介绍四个常用方法: addAll(Collection ...

  6. P2756 飞行员配对方案问题 二分图匹配 匈牙利算法

    题目背景 第二次世界大战时期.. 题目描述 英国皇家空军从沦陷国征募了大量外籍飞行员.由皇家空军派出的每一架飞机都需要配备在航行技能和语言上能互相配合的2 名飞行员,其中1 名是英国飞行员,另1名是外 ...

  7. DFS——深度优先搜索的一般格式

    DFS是一种深度优先的搜索思想,运用递归完成搜索,本质上也算是穷举思想的一类,可以通过剪枝进行优化. DFS的核心是回溯和递归, 如果以迷宫为例,一般会指定走各个方向的顺序(例如先左再上再右再下).从 ...

  8. 曹工说Spring Boot源码(11)-- context:component-scan,你真的会用吗(这次来说说它的奇技淫巧)

    写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...

  9. Ansible playbooks常用模块案例操作

    打开git bash 连接ansible服务器,然后进入deploy用户 #ssh root@192.168.96.188 进入python3.6虚拟环境 #su - deploy #source . ...

  10. IDEA 公司推出新字体,极度舒适~

    这几天炒得沸沸扬扬的 Intellij IDEA 公司 JetBrains 推出了一种新字体:JetBrains Mono,据说它是专为开发人员设计的,下面栈长带大家一起来吃个瓜. JetBrains ...