【代码随想录】LC 27. 移除元素

news2024/11/25 2:56:19

文章目录

  • 前言
  • 一、题目
    • 1、原题链接
    • 2、题目描述
  • 二、解题报告
    • 1、思路分析
    • 2、时间复杂度
    • 3、代码详解
  • 三、知识风暴

前言

本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。

一、题目

1、原题链接

27. 移除元素

2、题目描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、解题报告

1、思路分析

  1. 暴力解法
    利用两层循环,第一层循环找到值等于val的元素,第二层循环“移除元素”。(数组移除元素就是将该位置后面的元素依次向前移动一个位置,从而达到“移除”的效果,注意移动的顺序:应该从待移动序列前往后依次向前移动,否则会造成数组元素值“丢失”)
  2. 双指针法
    设置两个指针,快指针用来遍历数组慢指针用来找到值为val的元素。具体流程:快指针和慢指针初始指向数组中第一个元素,然后快指针向后遍历数组,当数组元素的值不等于val时,慢指针也向后移动,同时记录该元素在数组中如果数组元素的值等于val时,慢指针不动,快指针继续向后遍历,直到数组元素的值不等于val,执行前述操作。直至快指针遍历完整个数组。算法结束,此时慢指针正好记录了移除重复元素后的数组长度

2、时间复杂度

暴力解法时间复杂度O(n^2)
双指针法时间复杂度O(n)

3、代码详解

暴力解法代码

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int cnt = nums.size(); 
        //注意循环条件i<cnt,不要写成i<nums.size()造成错误   
        for (int i = 0; i < cnt; i++) {
            if (nums[i] == val) {
                //“移除”过程:i位置后的所有元素向前移动一个位置
                for (int j = i + 1; j < cnt; j++) {
                    nums[j-1] = nums[j];
                }
                cnt--;
                //i后面元素都向前移动了一个位置,i也向前移动一个位置
                //下一次循环时相当于i没有动,而元素向前移动了一个位置
                //i也就指向了下一个需要遍历的数组元素
                i--;
            }
        }
        return cnt;
    }
};

双指针法代码

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int slowPoint=0;
        //快指针遍历数组
        for (int fastPoint = 0; fastPoint < nums.size(); fastPoint++) {
            //慢指针记录结果:只记录值不为val的所有元素
            if (nums[fastPoint] != val) {
                nums[slowPoint++]=nums[fastPoint];
            }
        }
        //此时slowPoint正好记录了移除重复元素后的数组元素个数
        return slowPoint;
    }
};

三、知识风暴

  • 双指针法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1067363.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

文创行业如何利用软文出圈?媒介盒子告诉你

经济快速发展与社会进步&#xff0c;带来的是人们消费观念的转型&#xff0c;人们的精神需求与文化自信不断增强&#xff0c;随着文化产业和旅游业的不断升级&#xff0c;文创产品凭借独特的概念、创新的形象&#xff0c;吸引许多消费者。那么新时代的文创行业应该如何强势出圈…

华为数通方向HCIP-DataCom H12-831题库(单选题:201-220)

第201题 DHCP Snooping是一种DHCP安全特性,这项技术可以防御以下哪些攻击? A、DHCP Server仿冒者攻击 B、针对DHCP客户端的畸形报文泛洪攻击 C、仿冒DHCP报文攻击 D、DHCP Server的拒绝服务攻击 答案:ABD 解析: 第202题 两台PE之间通过MP-BGP传播VPNv4路由,以下哪些场景…

csa从初阶到大牛(网络配置)

添加新的网络连接ens170&#xff0c;并设置静态IP地址 sudo vi /etc/sysconfig/network-scripts/ifcfg-ens170TYPEEthernet BOOTPROTOstatic DEFROUTEyes NAMEens170 DEVICEens170 ONBOOTyes IPADDR192.168.1.100 NETMASK255.255.255.02.向ens170网络连接添加2个ip地址 sudo …

2023年中国铁路通信系统发展历程、市场规模及行业发展趋势分析[图]

铁路通信技术是铁路行业发展的重要推动力&#xff0c;它不仅可以提高客运、货运、维修、安全等业务的运行效率&#xff0c;还能够有效提高铁路行业的客户服务水平&#xff0c;实现质量和效率的双重提升。我国通信技术在铁路领域的应用经历了三个阶段&#xff0c;分别是模拟通信…

VulnHub JANGOW

提示&#xff08;主机ip分配问题&#xff09; 因为直接在VulnHub上下载的盒子&#xff0c;在VMware上打开&#xff0c;默认是不分配主机的 所以我们可以在VirtualBox上打开 一、信息收集 发现开放了21和80端口&#xff0c;查看一下80端口 80端口&#xff1a; 检查页面后发现…

小白必看!上位机控制单片机原理

嗨&#xff0c;大家好&#xff01;今天&#xff0c;我们要探讨一个有趣的话题——"以上位机控制单片机"。不要担心&#xff0c;我们会用最简单的方式来解释这个概念。 首先&#xff0c;你可以把以上位机想象成一台超级聪明的电脑&#xff0c;就像你用来上网、玩游戏、…

参与现场问题解决总结(Kafka、Hbase)

一. 背景 Kafka和Hbase在现场应用广泛&#xff0c;现场问题也较多&#xff0c;本季度通过对现场问题就行跟踪和总结&#xff0c;同时结合一些调研&#xff0c;尝试提高难点问题的解决效率&#xff0c;从而提高客户和现场满意度。非难点问题&#xff08;历史遇到过问题&#xf…

零代码编程:用ChatGPT绕过网站的Cloudflare防护爬取网页数据

打开这个网页&#xff0c;想爬取网页上的内容&#xff1a; https://toppsta.com/books/series/29278/national-geographic-kids-readers-level-1 这个网页看起来很简单&#xff0c;但是一般手段根本无法获取源代码&#xff0c;因为网站使用了Cloudflare服务器进行防护。 可以使…

leetCode 674. 最长连续递增序列 动态规划 / 贪心策略

674. 最长连续递增序列 - 力扣&#xff08;LeetCode&#xff09; 给定一个未经排序的整数数组&#xff0c;找到最长且 连续递增的子序列&#xff0c;并返回该序列的长度。 连续递增的子序列 可以由两个下标 l 和 r&#xff08;l < r&#xff09;确定&#xff0c;如果对于每…

JHipster数据权限使用

一、在JDL的application配置中添加feature&#xff1a;dataScope application {config {applicationType monolithtitle "瀚海工作平台"footer ""baseName LimsMonolithpackageName com.eyunappVersion "0.0.1"serverPort 8891authenticationTy…

010:连续跌3天,同时这三天收盘价都在20日均线下,第四天上涨的概率--以京泉华为例

对于《连续跌三天&#xff0c;压第四天上涨的盈利计算》&#xff0c;我们可以继续优化这个策略&#xff0c;增加条件&#xff1a;同时三天都收盘在20日均线下。 因为我们上一篇《获取20日均线数据到excel表中》获得了20日均线数据&#xff0c;我们可以利用均线数据来编写新的脚…

神经辐射场(NeRF)中-相机参数与坐标系变换

NeRF: Representing Scenes as Neural Radiance Fields for View Synthesis 是一篇获得ECCV2020 Best Paper Honorable Mention的论文。给定一个场景的多视角的图像&#xff0c;神经辐射场&#xff08;NeRF&#xff09;通过图像重建误差优化一个神经场景表征。优化后可以实现逼…

布隆过滤器及其用法

1 定义 布隆过滤器(Bloom Filter, BF)是由Howrad Bloom在1970年提出的一种具有高效时间和空间效率的二进制向量数据结构&#xff0c;用来检测一个元素是不是属于这个集合。注意&#xff0c;布隆过滤器只判断是否出现在集合中&#xff0c;无法给出元素在集合中的具体位置。 1.1…

C语言内存函数

目录 memcpy(Copy block of memory)使用和模拟实现memcpy的模拟实现 memmove(Move block of memory)使用和模拟实现memmove的模拟实现: memset(Fill block of memory)函数的使用扩展 memcmp(Compare two blocks of memory)函数的使用 感谢各位大佬对我的支持,如果我的文章对你有…

JavaScript小游戏实现高分榜

之前我们实现了游戏的主体功能&#xff0c;以及恢复之类的功能&#xff01;本次我们来实现高分榜的功能 功能的需求如下&#xff1a; ● 这个逻辑非常的简单&#xff0c;就是当我们猜对了数字后&#xff0c;跟我们的highscore做比较&#xff0c;如果比highscore高的话&#x…

跨境电商系统对接-进口

一、跨境进口方式 1、一般贸易 指中国境内有进出口经营权的企业进行进出口贸易&#xff0c;货物到港后需要先清关&#xff08;办理海关申报、查验、征税、放行等手续&#xff09;&#xff0c;然后货主才能提货&#xff0c;一般贸易适合大批量进口商品&#xff0c;公司的鲜奶、…

面试题:单核 CPU 支持 Java 多线程吗?为什么?被问懵了!

文章目录 前言时间片超线程上下文切换切换查看线程调度引起线程上下文切换的因素总结 前言 由于现在大多计算机都是多核CPU&#xff0c;多线程往往会比单线程更快&#xff0c;更能够提高并发&#xff0c;但提高并发并不意味着启动更多的线程来执行。更多的线程意味着线程创建销…

厌烦了iPhone默认的热点名称?如何更改iPhone上的热点名称

你对你默认的热点名称感到厌倦了吗&#xff1f;这篇文章是为你准备的。在这里&#xff0c;你可以了解如何轻松更改iPhone上的热点名称。 个人热点会将你的手机数据转换为Wi-Fi信号。手机上的个人热点使用户能够与其他用户共享其蜂窝数据连接。当你在WIFI网络之外时&#xff0c…

更轻便使用Siri!iOS 17让你用Siri的效率倍增

安装iOS 17后&#xff0c;你可以学习如何连续发出一个接一个的Siri请求。只要你有iPhone 11或iPhone SE第二代或更高版本&#xff0c;你就不需要不断重新激活Siri来提出后续请求。你只需要继续说下去。 Siri聪明的是&#xff0c;它可以了解你所问的要点。例如&#xff0c;你可…

根据中序与后序遍历结果构造二叉树

文章前言&#xff1a;对于中序与后序遍历不是太清楚的小白同学&#xff0c;作者推荐&#xff1a; 二叉树的初步认识_加瓦不加班的博客-CSDN博客 解题思路&#xff1a; 先通过后序遍历结果定位根节点 再结合中序遍历结果切分左右子树 代码实现&#xff1a; //1. pre-order 前…