删除数组中重复的元素(leetcode算法练习)

这道LeetCode题目要求在原地修改输入数组,删除重复元素,保持每个元素只出现一次。通过遍历数组并比较相邻元素来实现,最终返回新长度。个人解题思路包括设置变量n,从第二个元素开始遍历,不相等则移动到下一个位置,最后返回n+1作为新长度。
摘要由CSDN通过智能技术生成

###题目:

给定一个数组,删除重复出现的元素,使得每个元素只出现一次,并返回数组的新长度。
 *   注意:不要使用额外的数组空间,必须在原地修改输入数组,并在使用O(1)额外空间的条件下完成
 *   示例:
 *             给定数组nums = [0,0,1,1,1,2,2,3,3,4]。
 *             函数因该返回新的长度5,并且原数组nums的前5个元素被修改为0,1,2,3,4。
 *             不需要考虑数组中超出新长度后面的元素。

### (个人)解题思路
 *    1、准备一个变量n,初始赋值为0。
 *    2、遍历数组元素,初始下标从1开始。
 *        (1)、开始判断首次a[0]与a[1]的值是否相等,如果不相等,则让n+1,同时把a[i]的值赋值给a[0+1];
 *            然后进入下一次a[n]与a[i]比对,也就是a[1] 与 a[2]比对,依次类推,直到比对完最后一个元素。
 *        (2)、因为n是从0开始的,n最后比对次数比“去掉重复元素个数后的数组长度(array.length)小了1”,所以返回值要加1。

package com.zpark.leetcode;

/**
 * @author LLJ
 * @time 2020-5-9 上午8:49:21
 * @Description 给定一个数组,删除重复出现的元素,使得每个元素只出现一次,并返回数组的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值