博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
11.删除有序数组中的重复项
阅读量:3977 次
发布时间:2019-05-24

本文共 640 字,大约阅读时间需要 2 分钟。

文章标题

一、题目描述

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

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

说明:

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

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

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

在这里插入图片描述

在这里插入图片描述

二、解题思路

使用双指针法,怎么去理解呢,我设置两个指针,一个在前一个在后,如下图:

在这里插入图片描述
此时我就要进行判断了,如果当前两个指针指向的值相等,那么q向后移动一位:
在这里插入图片描述
如果不相等,将q指针指向的元素的值赋值到p+1指针指向的位置处:
在这里插入图片描述
q指向2与此时p指向的位置的值不同,将2复制给当前的p+1指向的位置:
在这里插入图片描述
在这里插入图片描述

最后输出返回p+1即可。

三、代码演示

class Solution {
public int removeDuplicates(int[] nums) {
//数组为空或者数组长度为1的情况直接返回 if(nums == null || nums.length == 1){
return nums.length; } //这个i相当于指针p int i = 0; //j相当于指针q进行数组的遍历 for(int j=1; j

转载地址:http://eogki.baihongyu.com/

你可能感兴趣的文章
PL/SQL Developer技巧
查看>>
3-python之PyCharm如何新建项目
查看>>
15-python之while循环嵌套应用场景
查看>>
17-python之for循环
查看>>
18-python之while循环,for循环与else的配合
查看>>
19-python之字符串简单介绍
查看>>
20-python之切片详细介绍
查看>>
P24-c++类继承-01详细的例子演示继承的好处
查看>>
P8-c++对象和类-01默认构造函数详解
查看>>
P1-c++函数详解-01函数的默认参数
查看>>
P3-c++函数详解-03函数模板详细介绍
查看>>
P4-c++函数详解-04函数重载,函数模板和函数模板重载,编译器选择使用哪个函数版本?
查看>>
P5-c++内存模型和名称空间-01头文件相关
查看>>
P6-c++内存模型和名称空间-02存储连续性、作用域和链接性
查看>>
P9-c++对象和类-02构造函数和析构函数总结
查看>>
P10-c++对象和类-03this指针详细介绍,详细的例子演示
查看>>
ksh 命令分隔符
查看>>
sed 精萃
查看>>
awk 精萃
查看>>
awk 注释
查看>>