返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言基础双指针移除元素解法
  • 216
分享到

C语言基础双指针移除元素解法

2024-04-02 19:04:59 216人浏览 独家记忆
摘要

本题方法:双指针。知识比较基础,思路简单 题目: 我的题解: int removeElement(int* nums, int numsSize, int val) {

本题方法:双指针。知识比较基础,思路简单

题目:

我的题解:


int removeElement(int* nums, int numsSize, int val)
{
    int i=0,j=0;
    int cnt=0;                 //计数器,用来统计val的个数
    while(j<numsSize)
    {
        if(nums[j]!=val)       //1
        {
            nums[i]=nums[j];
            i++;
            j++;
        }    
        else                  //2                  
        {
            j++;
            cnt++;
        }
    }
    return numsSize-cnt;      //3
}

关于我的解法思路:

我们先举个例子,比如{2,5,7,9,9,1,0}val=9

刚开始我们让指针都指向0位置,也就是nums[0],j为快指针,i为慢指针

如果j指向的地方不是val(也就是9),那我们就直接让nums[j]覆盖nums[i],并且i++,j++,让两个指针都指向下一个位置,如下图:

如此重复,指向7也是同理

指向7这个元素后,i++,j++,这时候,两个指针都到了val(也就是9)这个地方

j指针 指向的就是我们要去掉的值val(9),也就是代码中的 2步骤,这时候我们 i指针不动,j指针继续往前走,cnt变量记录val出现的次数,cnt++。

j到了第二个9的时候 ,j指针还是继续往前走i指针还是不变,cnt依旧++,如下图

这时候,j指针指向的是1,就不是val的值了,我们就直接把nums[j]覆盖nums[i],也就是把1覆盖9了,那就两个指针都往前走,同理j指向0,不是val,那就继续覆盖。

返回值:就是数组总个数numsSize减去val出现的次数cnt。

双指针大致思路如上,有意见欢迎指出~

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C语言基础双指针移除元素解法

本文链接: https://lsjlt.com/news/161200.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言基础双指针移除元素解法
    本题方法:双指针。知识比较基础,思路简单 题目: 我的题解: int removeElement(int* nums, int numsSize, int val) { ...
    99+
    2024-04-02
  • C语言指针基础详解
    目录1.1:概述1.1.1:内存1.1.2:内存1.1.3:指针和指针变量1.2:指针基础知识1.2.1:指针变量的定义和使用1.2.2:通过指针间接修改变量的值1.2.3:指针的大...
    99+
    2024-04-02
  • c语言 指针零基础讲解
    1.指针是什么(可能有点难理解) 指针的是啥? 指针实际上就是地址,地址就是系统给定的编号,编号就是一个个内存单元。 在某种情况来说指针=地址=编号=内存单元。 指针就是地址,顾名思...
    99+
    2024-04-02
  • C语言基础指针详解教程
    目录1.1:概述1.1.1:内存1.1.2:内存1.1.3:指针和指针变量1.2:指针基础知识1.2.1:指针变量的定义和使用1.2.2:通过指针间接修改变量的值1.2.3:指针的大...
    99+
    2024-04-02
  • 零基础详解C语言指针进阶
    目录前言1.字符指针例题 12.指针数组例题 23.数组指针3.1数组指针的定义3.2 &数组名与数组名3.3 数组指针的使用4.数组与指针在函数里的传参4.1 一维数组的传...
    99+
    2024-04-02
  • C语言零基础讲解指针和数组
    目录一、指针和数组分析-上1.数组的本质2.指针的运算3.指针的比较4.小结二、指针与数组分析-下 1.数组的访问方式2.下标形式 VS 指针形式3.a 和 &a ...
    99+
    2024-04-02
  • C语言怎么移除链表元素
    这篇“C语言怎么移除链表元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言怎么移除链表元素”文章吧。1、移除链表元素链...
    99+
    2023-06-29
  • C语言基础野指针与空指针示例分析
    目录一:野指针野指针的成因1. 指针未初始化2. 指针越界访问3 .指针释放后未置空规避野指针1. 初始化指针 2. 避免指针越界 3 避免返回局部变量的地址 4. 开辟的指针释放后...
    99+
    2024-04-02
  • C语言双指针算法怎么用
    这篇“C语言双指针算法怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言双指针算法怎么用”文章吧。双指针首先咱得知道...
    99+
    2023-06-29
  • C语言移除元素的三种思路讲解
    目录问题描述解题方案思路一思路二思路三(最优解)问题描述 原题链接:https://leetcode.cn/problems/remove-element/ 解题方案 思路一 思路...
    99+
    2022-11-13
    C语言移除元素 C语言删除元素
  • C语言基础知识点指针的使用
    目录一、指针的作用二、地址与指针三、指针变量四、数组与指针五、指针自加自减运算六、指向指针的指针七、指针变量作为函数形参八、函数指针九、函数指针数组十、指针的应用场景一、指针的作用 ...
    99+
    2024-04-02
  • C语言指针必备基础全面覆盖
    目录前言一、指针是什么?1.数据在内存中的存储2.一个小的单元到底是多大?二、指针变量1.什么是指针变量2.指针类型3.指针类型的作用三、野指针1.什么是野指针2.野指针成因2.1....
    99+
    2024-04-02
  • C语言指针之必须要掌握的指针基础知识
    目录一、指针概述指针的创建指针的大小如何使用指针二级指针二、野指针形成野指针的原因如何规避野指针三、指针的基本运算指针± 整数指针-指针四、指针和数组五、指针数组总结一、指针概述 指...
    99+
    2024-04-02
  • Go语言基础学习之指针详解
    目录1. 什么是指针2. 指针地址 & 指针类型3. 指针取值4. 空指针5. make6. new7. make 和 new 的区别8. 问题今天来说说 Go 语言基础中的...
    99+
    2022-12-30
    Go语言指针使用 Go语言指针 Go 指针
  • c语言怎么删除数组指定元素
    在C语言中,要删除数组中的指定元素,可以采用以下步骤:1. 遍历数组,找到要删除的元素的索引。2. 如果找到要删除的元素,则将后面的...
    99+
    2023-08-31
    c语言
  • C语言双指针多方法旋转数组解题LeetCode
    目录暴力思路外加数组格局抬高环形替代LeetCode题目如下: 首先这个中等难度我是没搞懂,后面才发现原来中等中在要求多方法上,那就来看看怎么搞定他吧。 暴力思路 首先我说一下我本...
    99+
    2024-04-02
  • c语言中指针零基础知识点有哪些
    小编给大家分享一下c语言中指针零基础知识点有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.指针是什么(可能有点难理解)指针的是啥?指针实际上就是地址,地址...
    99+
    2023-06-29
  • c语言怎么删除指定位置的元素
    在C语言中,要删除指定位置的元素,需要将该位置后面的元素都向前移动一个位置,并更新数组的大小。以下是一个示例代码: #include...
    99+
    2024-03-14
    c语言
  • C语言双指针算法朋友过情人节我过算法
    目录双指针对撞指针快慢指针真题实战双指针 首先咱得知道何为双指针,听起来很上流,其实有手就行。 双指针,指的是在遍历对象的过程中,不是普通的使用单个指针进行访问,而是使用两个相同方向...
    99+
    2024-04-02
  • C语言详细讲解指针数组的用法
    目录1. 指针数组定义方法2. 指针的指针(二级指针)3. 字符串和指针4. 数组指针定义方法数组指针的用法1. 指针数组定义方法 格式: 类型说明符 *数组名[ 元素个数 ] in...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作