内容简介:不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。划重点:1.排序数组 2.原地删除错误思路:
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
划重点:1.排序数组 2.原地删除
错误思路:
1.声明一个tmp,初始就是nums[0],用作被比较的对象
2.用tmp去和每一个后面的数去对比,相同的跳过,不同的,先把nums[j]设成tmp,然后j++,tmp变成不同的那个数
错误点:
1.使用了新的内存空间,是错误的
2.tmp要和后面的数去比,tmp如果走到了最后一个,那么后面必然会产生越界。
3.tmp最后一定是一个和前面不同的数,这个数不参与比较,那么一定不会被覆盖写入数组
比如{1,1,2,2,3,3}->{1,2,2,2,3,3}
public static int removeDuplicates(int[] nums)
{
int i = 0, j = 0;
int tmp = nums[0];
for(i = 1; i < nums.length; i++)
{
if(nums[i] == tmp)
{
continue;
}
else
{
nums[j] = tmp;
tmp = nums[i];
j++;
}
}
System.out.println(j+1);
return j+1;
}
思路:
要求原地删除,那么一定使用快慢指针进行元素的覆盖操作。
声明两个指针,i为快指针,j为慢指针
如果遇到相同的数,那么就跳过,i++。
如果遇到不同的数,将这个值的下一个数给替换成这个不一样的值。
public static int removeDuplicates(int[] nums)
{
int i = 0, j = 0;
for(i = 1; i < nums.length; i++)
{
if(nums[j] == nums[i])
{
continue;
}
else
{
j++;
nums[j] = nums[i];
}
}
System.out.println(j+1);
return j+1;
}
代码写的不够优雅,因为判断相等然后continue是没有必要的,优化一下:
public static int removeDuplicates(int[] nums)
{
int j = 0;
for(int i = 1; i < nums.length; i++)
{
if(nums[j] != nums[i])
{
j++;
nums[j] = nums[i];
}
}
return j+1;
}
复杂度分析:
遍历一遍,时间复杂度o(n)
空间复杂度,o(1)
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
网络经济的十种策略
(美)凯文・凯利 / 肖华敬/任平 / 广州出版社 / 2000-06 / 26.00元
全书介绍网络经济的十个新游戏规则,分别是:蜜蜂比狮子重要;级数比加法重要;普及比稀有重要;免费比利润重要;网络比公司重要;造山比登山重要;空间比场所重要;流动比平衡重要;关系比产能重要;机会比效率重要!一起来看看 《网络经济的十种策略》 这本书的介绍吧!
图片转BASE64编码
在线图片转Base64编码工具
XML 在线格式化
在线 XML 格式化压缩工具