题目:27.移除元素

方法①-遍历删除
思路:遍历遇到val,挪动覆盖删除
时间复杂度:O(n2)
最坏情况:全是2,因此就是一个等差数列
int removeElement(int* nums, int numsSize, int val)
{
int temp = numsSize ; //临时保存变量,返回时候要用
int count = 0; //统计移除元素的个数
for(int i = 0;i <numsSize;i++)
{
if(val == nums[i])
{
count++;
for(int j = i;j<numsSize -1;j++)
{
nums[j] = nums[j+1];
}
numsSize--;
i--; //由于元素都是往前移动了,所以i也要--
}
}
return temp - count;
}
方法②-以空间换时间
思路:创建一个临时数组tmp,把nums数组中,不等于val的值,移动到临时数组tmp中,然后再把tmp的值覆盖回去nums中,并释放tmp
时间复杂度:O(n)
空间复杂度:O(n)
int removeElement(int* nums, int numsSize, int val)
{
int *tmp = (int*)malloc(sizeof(int)*numsSize);
int j = 0;//执行临时数组的下标
//找不等于val的值放到临时数组
for(int i = 0;i<numsSize;i++)
{
if(val != nums[i])
{
tmp[j++] = nums[i];
}
}
//把临时数组的值,覆盖回去
//上面的循环结束后,j = 不是val元素的个数
for(int i = 0;i<j;i++)
{
nums[i] = tmp[i];
}
return j;
}
方法③-双指针
思路:定义两个指针:一个dst,一个src;
dst表示目的地指针,src是源指针,src用来移动寻找不等于val的值;
src找到不等于val的值那么就把它赋值给dst对应的值,即nums[dst] = nums[src],同时dst++;src++;
src碰到于val相等的值,那么src++;其他不变;
int removeElement(int* nums, int numsSize, int val)
{
int dst = 0, src = 0;
while(src < numsSize)
{
if(nums[src] !=val)
{
nums[dst++] = nums[src++];
}
else
{
src++;
}
}
//当退出循环后,dst就是元素个数
return dst;
}