C语言移除元素的三种思路讲解

 更新时间:2022年10月19日 11:20:13   作者:小牛要翻身  
这篇文章主要介绍了C语言移除元素的三种思路,总的来说这并不是一道难题,那为什么要拿出这道题介绍?拿出这道题真正想要传达的是解题的思路,以及不断优化探寻最优解的过程。希望通过这道题能给你带来一种解题优化的思路

问题描述

原题链接:https://leetcode.cn/problems/remove-element/

解题方案

思路一

思路一:

首先通过简单分析,很明显这是一道顺序表相关问题。首先能够想到的是暴力求解,即思路一:找到所有的val,每次挪动val后的数据覆盖删除val。

📝代码展示:

int find(int*nums,int numsSize,int val)
{
     int i=0;
    for(i=0;i<numsSize;i++)
    {
        if(nums[i]==val)
            return i;
    }
    return -1;
}
int removeElement(int* nums, int numsSize, int val)
{
   int ret;
    while((ret=find(nums,numsSize,val))!=-1)
    {
        for(int i=ret;i<numsSize-1;i++)
        {
            nums[i]=nums[i+1];
        }
        numsSize--;
    }
   return numsSize;
}

但是对于思路一,空间复杂度显然是O(1),当我们计算时间复杂度的时候,最坏的情况是数组中大部分值都为val,这时时间复杂度近似为O(1+2+……+n-1)即O(n^2),显然O(n^2)的时间复杂度还是不尽人意,本着降低时间复杂度,我们可以怎样优化呢?

思路二

思路二:

在创建一个临时数组tmp,遍历nums数组,把不是val的数值放到tmp数组,最后把tmp数组的内容依次拷贝到nums数组,返回tmp数组长度。

📝代码展示:

int removeElement(int* nums, int numsSize, int val)
{
    if(numsSize==0)//特殊处理
        return 0;
    int i=0;
    int tmp[numsSize];
    int count=0;
    for(i=0;i<numsSize;i++)
    {
        if(nums[i]!=val)
        {
            tmp[count]=nums[i];
            count++;
        }
    }
    for(i=0;i<numsSize;i++)
    {
        nums[i]=tmp[i];
    }
    return count;
}

注释:这里的特殊处理是因为在函数中使用了变长数组 int tmp[numsSize];而变长数组的大小不能为0,这是使用特殊处理,是因为力扣的测试用例中含有[] 0

对于思路二,最坏的情况我们只遍历了1遍数组,即时间复杂度为O(n),但是这明显是一种用空间换区时间的方法,在此过程我们创建了numsSize个变量,即空间复杂度为O(n)。所以我们能不能通过再降低空间复杂度,进一步优化呢?

思路三(最优解)

思路三:

创建两个变量src、dest,初始时指向首部,判断nums[src]是否等于val,如果等于val则dest指向不动,src向后偏移,直到nums[src]!=val,令nums[dest]=nums[src],然后src、dest都向后偏移,直到src遍历完数组,程序结束。

📝代码展示:

int removeElement(int* nums, int numsSize, int val)
{
    int src=0;
    int dest=0;
    while(src<numsSize)
    {
        if(nums[src]!=val)
        {
            nums[dest]=nums[src];
            src++;
            dest++;
        }
        else
            src++;
    }
    return dest;
}

这种思路下时间复杂度为遍历整个数组O(n),创建的变量为有限个,所以空间复杂度为O(1)。相比之下为最优解。

到此这篇关于C语言移除元素的三种思路讲解的文章就介绍到这了,更多相关C语言移除元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • udp socket客户端和udp服务端程序示例分享

    udp socket客户端和udp服务端程序示例分享

    这篇文章主要介绍了udp socket客户端和udp服务端程序示例,需要的朋友可以参考下
    2014-03-03
  • C语言算法的时间复杂度和空间复杂度

    C语言算法的时间复杂度和空间复杂度

    这篇文章主要介绍了C语言算法的时间复杂度和空间复杂度,算法在编写成可执行程序后,运行时需要耗费时间资源和空间(内存)资源,更多相关需要的朋友可以参考一下
    2022-07-07
  • C语言基础应用处理学生打分 计算时间 最少硬币问题详细过程

    C语言基础应用处理学生打分 计算时间 最少硬币问题详细过程

    很多的问题其实可以用编程来解决作答,本篇文章带你用C语言解决最少硬币问题、计算已经过去了多久、学生成绩自动打分来做基础的训练
    2022-02-02
  • C语言模拟实现字符串库函数的示例讲解

    C语言模拟实现字符串库函数的示例讲解

    这篇文章主要为大家详细介绍了C语言模拟实现字符串库函数的具体方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01
  • C++如何将vector数字写入到txt文件中

    C++如何将vector数字写入到txt文件中

    这篇文章主要介绍了C++如何将vector数字写入到txt文件中问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 浅谈c++11线程的互斥量

    浅谈c++11线程的互斥量

    互斥量是个类对象,理解成一把锁(保护共享数据,其他想操作共享数据的线程必须等待解锁),互斥量使用要小心,保护数据不多也不少,少了则没达到保护效果,多了则影响效率。本文将介绍c++11线程的互斥量,感兴趣的同学,可以参考下。
    2021-06-06
  • 浅谈c++中的while(cin)问题

    浅谈c++中的while(cin)问题

    下面小编就为大家带来一篇浅谈c++中的while(cin)问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • C语言菜鸟基础教程之单精度浮点数与双精度浮点数

    C语言菜鸟基础教程之单精度浮点数与双精度浮点数

    在C语言中,单精度浮点数(float)和双精度浮点数(double)类型都是用来储存实数的,双精度是用记忆较多,有效数字较多,数值范围较大。
    2017-10-10
  • C语言实现24位彩色图像二值化

    C语言实现24位彩色图像二值化

    这篇文章主要为大家详细介绍了C语言实现24位彩色图像二值化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 详解C++编程中的变量相关知识

    详解C++编程中的变量相关知识

    这篇文章主要介绍了详解C++编程中的变量相关知识,是C++入门学习中的基础知识,需要的朋友可以参考下
    2015-09-09

最新评论