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,以下为详细部署步骤。
1262 0
|
分布式计算 Java Hadoop
Hadoop垃圾回收机制
Hadoop垃圾回收机制
|
缓存 前端开发 JavaScript
浅浅阅读umi中InitialState插件源码 - 杨磊
InitialState插件源码的简要介绍
1257 0
浅浅阅读umi中InitialState插件源码 - 杨磊
|
监控 数据安全/隐私保护 Android开发
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
用最简单的方法下载微信视频号中的视频:微信视频号下载工具!
|
XML Java Android开发
Androistudio lint检查去除无效代码、无效资源
Androistudio lint检查去除无效代码、无效资源
508 0
|
移动开发 前端开发 JavaScript
原生 JS 手写一个优雅的图片预览功能,带你吃透背后原理
本文将用一个极简的例子详细讲解如何用原生JS一步步实现完整的图片预览和查看功能,无任何第三方依赖,兼容PC与H5,实现了触屏双指缩放等,干货满满。
原生 JS 手写一个优雅的图片预览功能,带你吃透背后原理
|
云安全 弹性计算 运维
混合云构架和场景|学习笔记
快速学习混合云构架和场景
混合云构架和场景|学习笔记
|
网络安全 API 开发工具
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
1168 0
【Python】【应用】Python应用之玩转gerrit系列之一——搭建基础环境
|
存储 关系型数据库 MySQL
Holo 使用场景说明
Holo 使用场景说明
|
缓存 前端开发 安全
SpringBoot 开发抖音开放平台获取用户的粉丝统计和短视频数据(二篇)
最近有朋友问起我有没有做过抖音开放平台,让我有了些思考,其实之前做过的。虽然抖音APP很火,但是毕竟不像微信开放平台那样,已沉淀多年,基本上每个API只要肯用心查找,网上都有很多资料可以参考。而抖音开放平台则不然,刚面世不久,资料比较少。即使对于一个开发人员来说,接入第三方接口都大同小异,不会太难,但我还是想把这些记录下来,特别是遇到的坑,会列在下面,一起参考学习。限于水平有限,若有错误,不吝赐教哈。那么,我们就开始正文吧。
1224 0
SpringBoot 开发抖音开放平台获取用户的粉丝统计和短视频数据(二篇)