手撕C语言题典——移除元素(顺序表)

搭配使用更佳哦~~

数据结构之顺顺顺——顺序表-CSDN博客

数据结构之顺序表的基本操作-CSDN博客

前面学了顺序表的相关知识,我们来尝试做一下关于顺序表的经典算法题~

前言 

27. 移除元素 - 力扣(LeetCode)

       移除元素作为力扣上的一道不算太难的算法题,很适合刚学过顺序表的我们拿来练手,大家也可以去力扣上自己 try 一下~

 一.思路

      我们先来理解一下题干:假设我们有一个这样的数组 nums:

nums

       假设 val = 3 ,那我们需要将 nums 中的 3 全部移除,于是我们数组元素 4 - > 2 ,这就是题干大致的意思,理解了题干后我们开始求解。

1)临时数组

      我们首先可以想到最简单的方法就是,创建一个新的数组,遍历原数组,将不为 val 的值放入新数组。

但由于题干中的限定条件:

这个方法只能pass掉。

2) 双指针

我们创建两个指针:

      src:源数据

      dst:目标指针

      我们假设还是这个数组元素,使用 src 这个指针开始遍历,如果元素是 val (也就是要删除的数据)就往后面的元素去遍历,当指向不是 val 的元素时,我们就把 src 指向的元素给给 dst ,然后 dst 自身 ++ ,向后面元素走一位, src ++。依次往后遍历 ,最终 src 跳出数组,dst 刚刚好等于2,就是我们想要得到的新数组。

我们可以总结一下双指针的思路了:

创建两个指针变量 src , dst  

  • 若 src 指向的值为 val,则 src++
  •  若 src 指向的值不为 val ,nums [ dst ] = nums [ src ],src ++,dst ++

 二.代码实现

int removeElement(int* nums, int numsSize, int val) {
//先创建两个变量
int src, dst;
src = dst = 0;
while (src < numsSize)
{
 	if (num[src] == val)
	{
		src++;
	}
	else {
		//赋值,两指针
		nums[dst] = nums[src];
		dst++;
		src++;
	}
}
//此时刚好dst是我们需要的新数组有效长度
return dst;
    
}

 下一篇会接着将另一道有关顺序表的算法题~~

🎈🎈完结撒花🎈🎈 

相关推荐

  1. 元素{c++}

    2024-04-30 05:40:01       26 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-30 05:40:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-30 05:40:01       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-30 05:40:01       82 阅读
  4. Python语言-面向对象

    2024-04-30 05:40:01       91 阅读

热门阅读

  1. windows11 磁盘扩容删除恢复分区

    2024-04-30 05:40:01       28 阅读
  2. linux命令:scp远程拷贝命令

    2024-04-30 05:40:01       34 阅读
  3. strcmp,strncmp函数详解

    2024-04-30 05:40:01       36 阅读
  4. 一款非常不错的音频录制播放Python库

    2024-04-30 05:40:01       40 阅读
  5. VS2019编译 Qt5.15.12 和 Qt6.5.3

    2024-04-30 05:40:01       35 阅读
  6. 【c++基础】求细胞数量

    2024-04-30 05:40:01       29 阅读
  7. 【考研数学】线代老师李永乐是否被高估了?

    2024-04-30 05:40:01       38 阅读
  8. IP路由安全:保护网络免受威胁

    2024-04-30 05:40:01       26 阅读