leetcode第26题

简介: for 循环遍历每个数,while 循环判断当前数和它的后一个数是否相等,相等就后移一个数,并且接着判断后移的数和它后边的数是否相等,然后一直循环下去。不相等就将后一个数保存起来,并且长度加 1,然后结束循环。

image.png

top26

返回非重复数字的个数,并且把 nums 里重复的数字也去掉。

例如,nums = [ 1, 1, 2 ] ,那么就返回 2 ,并且把 nums 变成 [ 1, 2 ]。

这道题,蛮简单的,但是自己写的时候多加了个 while 循环,但和给出的 Solution 本质还是一样的。

我写的

for 循环遍历每个数,while 循环判断当前数和它的后一个数是否相等,相等就后移一个数,并且接着判断后移的数和它后边的数是否相等,然后一直循环下去。不相等就将后一个数保存起来,并且长度加 1,然后结束循环。

publicintremoveDuplicates(int[] nums) {
intlen=1;
for (inti=0; i<nums.length-1; i++) {
while (i<nums.length-1) {
if (nums[i] ==nums[i+1]) {
i++;
            } else {
nums[len] =nums[i+1];
len=len+1;            
break;
            }
        }
    }
returnlen;
}

时间复杂度: O(n)。

空间复杂度:O(1)。

Solution 给出的

利用快慢指针,i 指针从 0 开始,j 指针从 1 开始,如果 i 和 j 所指数字相等,就一直后移 j 。如果不相等,i 指针后移一位用来保存当前 j 所指的值,然后继续回到 j 的后移中去。

publicintremoveDuplicates(int[] nums) {
if (nums.length==0) return0;
inti=0;
for (intj=1; j<nums.length; j++) {
if (nums[j] !=nums[i]) {
i++;
nums[i] =nums[j];
        }
    }
returni+1;
}

时间复杂度: O(n)。

空间复杂度:O(1)。

不同的思想,决定了写出来的代码不同,但就时间复杂度来看,它们本质还是一样的。


相关文章
|
监控 数据可视化 关系型数据库
PostgreSQL主备库搭建
pg主备库的搭建,首先需在2个节点安装pg软件,然后依次在2个节点配置主备。 本文采用os为CentOS7.6,pg版本使用14.2,以下为详细部署步骤。
1021 0
|
分布式计算 Java Hadoop
Hadoop垃圾回收机制
Hadoop垃圾回收机制
|
缓存 前端开发 JavaScript
浅浅阅读umi中InitialState插件源码 - 杨磊
InitialState插件源码的简要介绍
1203 0
浅浅阅读umi中InitialState插件源码 - 杨磊
|
监控 数据安全/隐私保护 Android开发
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
|
XML Java Android开发
Androistudio lint检查去除无效代码、无效资源
Androistudio lint检查去除无效代码、无效资源
469 0
|
移动开发 前端开发 JavaScript
原生 JS 手写一个优雅的图片预览功能,带你吃透背后原理
本文将用一个极简的例子详细讲解如何用原生JS一步步实现完整的图片预览和查看功能,无任何第三方依赖,兼容PC与H5,实现了触屏双指缩放等,干货满满。
原生 JS 手写一个优雅的图片预览功能,带你吃透背后原理
|
Linux 数据安全/隐私保护
五分钟学会虚拟机centos 7忘记root密码如何解决(你想要什么,不要等人送)
五分钟学会虚拟机centos 7忘记root密码如何解决(你想要什么,不要等人送)
671 0
五分钟学会虚拟机centos 7忘记root密码如何解决(你想要什么,不要等人送)
|
网络安全 API 开发工具
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
1057 0
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
|
安全 网络安全 数据库
智能接入网关的概念和产品优势|学习笔记
快速学习智能接入网关的概念和产品优势
智能接入网关的概念和产品优势|学习笔记
|
存储 关系型数据库 MySQL
Holo 使用场景说明
Holo 使用场景说明