【手撕OJ题】——27.移除元素(三种思路:C实现)

本文详细介绍了LeetCode第27题的三种解决方案:遍历删除、以空间换时间和双指针方法。分别讨论了它们的时间复杂度和空间复杂度,并提供了具体的C语言实现代码。这三种方法分别针对不同的操作效率和资源使用进行了优化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目: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
27题思路2
时间复杂度: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;
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值