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)。

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


相关文章
|
8月前
|
算法
leetcode:389. 找不同
leetcode:389. 找不同
32 0
|
8月前
leetcode232刷题打卡
leetcode232刷题打卡
32 0
|
8月前
|
算法
leetcode28刷题打卡
leetcode28刷题打卡
35 0
单链表反转 LeetCode 206
单链表反转 LeetCode 206
82 0
|
测试技术 索引
leetcode刷题(2)
各位朋友们,又是新的一天,不知道大家过得怎样?今天是我leedcode刷题系列的第二篇,那么废话不多说,直接进入我们今天的主题。
|
存储 测试技术
leetcode刷题(1)
各位朋友们,大家好,从今天开始我将陆续为大家更新我自己每天的leedcode刷题,我将会为大家说明每一步的来由,保证你一天新学会几道题目。各位朋友可以跟着博主每天刷几道题,相信两个月后大家的代码能力可以得到明显的提高。那么接下来就开始今天的刷题之路了哦。
|
人工智能
LeetCode刷题day59(下)
LeetCode刷题day59(下)
LeetCode刷题day59(下)