【数据结构】顺序表专题

前言

本篇文章我们来进行有关顺序表的专题训练,让我们一起来看一下有关顺序表的算法题

💓 个人主页:小张同学zkf

⏩ 文章专栏:数据结构

📝若有问题 评论区见

🎉欢迎大家点赞👍收藏⭐文章

 1.移除元素

这道题看似简单,但我们不要忘了其中有个条件限制,空间复杂度O(1),所以做这道题时,我们不能创一个新的空间,否则空间复杂度过大与题不符。

所以我们最容易想到的第一种解法,创建新的数组,遍历原数组的思路就不行了

既然不能创建新的空间,那我们就只能在原数组内更改,这里我们有第二种思路,双指针法,创建两个指针,两个指针刚开始同时指向这个数组的首元素,一个指针用来在顺序表上遍历,若与要删除目标相等则继续往后遍历,若与要删除目标不相等,则将现在所指向的值直接赋值与另一个指针指向处,然后俩指针同时向后走,重复这个过程直到指向空,最后那个没指向空的指针就是要返回的长度

 

 

代码如下

 

有些人在这可能有些疑惑,说指针也没用指针呀,其实数组的下标性访问,就是指针访问嘛,一个思路嘛。 


2. 合并两个有序数组

第一种思路我们很容易想到的直接冒泡排序,但这个效率太低了,时间复杂度高

我们第二种思路三指针法,需要用到三个指针,l1指向下标为m处,l3指向下表为n+m-1处,l2指向第二个数组的最后一个元素处。然后l1和l2比较谁大放l3处,小的那个指针与l3向前移,重复这个过程直到l1都指向初始位置,或l2指向初始位置。

这里或许有人疑问了为什么是从后往前比较,而不是从前往后比较,我们仔细想一下若从前往后比较我们很有可能把原值覆盖,但从后往前比较就不会出现覆盖情况

这里结果就有两种情况,若l2先出循环正好有序,而且l2和l1已完全合并成一个数组,但若l1先出循环,l2还有数据没放到l1中,这里直接让l2剩余部分直接尾插到l1中就行了。 

 

代码如下: 

 


结束语 

本篇博客列举了两道有关顺序表的算法题,算是两道经典题了,若有什么问题,可以在评论区交流,下片博客我们继续对链表专题进行补充

OK,感谢观看!!!!

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 可以对数据进行哪些可视化?

Python 可视化 一、条形图(或柱状图) 1.代码如下: import matplotlib.pyplot as plt import pandas as pddf pd.DataFrame({County:[America,Canada,Australia,Germany,French,China],GDP:[80,30,70,80,60,75] })plt.bar(df[County],df[G…

Docker consul 的容器服务更新与发现

目录 一. consul 的相关知识 1 什么是注册与发现 2. 什么是 consul 3. zookeeper 和 consul 的区别 二. consul 部署 1. consul 服务器 2. registrator 服务器 三. consul-template 1. consul-template 的作用 2. consul-template 的具体部署运用 2.1 准备 templa…

容器的通俗讲解:轻松理解容器技术

文章目录 什么是容器?容器与虚拟机的区别容器如何工作?容器的优势容器的应用场景常见容器技术相关解决方案 在当今的软件开发领域,容器技术已经成为一种异常流行的技术,但对于初学者来说,容器究竟是什么以及它们如何工…

由于找不到msvcr80.dll,无法继续执行代码的解决方法

在日常使用电脑进行工作或娱乐时,您可能会遇到一个令人困惑的情况:屏幕上突然弹出一个错误提示,明确指出“msvcr80.dll文件丢失”,这个错误通常会导致某些应用程序无法正常运行。那么,当我们遇到这个问题时&#xff0c…

UE5像素流部署以及多实例部署(兼容ue4)

像素流部署请看我之前的文章就行,今天讲的是多实例部署 在这里可以配置多实例的数量 如果设置800端口 设置两个实例 那么就是800 801端口 我的个人显卡是4060TI,最多开三个

大数据分析与内存计算学习笔记

一、Scala编程初级实践 1.计算级数: 请用脚本的方式编程计算并输出下列级数的前n项之和Sn,直到Sn刚好大于或等于q为止,其中q为大于0的整数,其值通过键盘输入。(不使用脚本执行方式可写Java代码转换成Scala代码执行&a…

通过ESXi主机和专业工具导出或导入虚拟机

关于导出虚拟机的用户场景 导出ESXi虚拟机是VMware内置功能之一,可用于数据迁移或作为ESXi备份解决方案。通常情况下,您可以将ESXi中的虚拟机导出为OVF模板,该模板可捕获虚拟机或虚拟设备的状态并存储在一个自包含的包中,其中磁盘…

Linux 设置 ssh 服务开机自启并允许 root 账户以密码验证身份登录

确保防火墙已允许 ssh 端口上的传入连接 一、查看系统是否已安装 OpenSSH Ubuntu dpkg --list | grep sshRedHat/CentOS rpm -qa | grep ssh二、修改 ssh 服务的 sshd_config 文件,以允许 root 账户以密码验证身份登录。 1、 从 sshd_config 中删除所有包含 “…

值得买科技新思路,导购电商的终点是“AI+出海”?

在以往,大众普遍认为品牌的消费者大多是高度忠诚人群,而事实上,非品牌忠诚者相比重度消费者,对促进品牌增长更为重要。 这类非品牌忠诚者被定义为摇摆的消费者群体,也就是那些购买品牌产品概率在20%-80%之间的消费者。…

新版本Qt Creator安装配置

新版本Qt Creator安装配置 文章目录 新版本Qt Creator安装配置1、前言2、环境3、安装配置4、总结 更多精彩内容👉个人内容分类汇总 👈👉Qt开发经验 👈 1、前言 Qt是一个跨平台的C应用程序开发框架,而Qt Creator是专为Q…

LLM 构建Data Multi-Agents 赋能数据分析平台的实践之③:数据分析之二(大小模型协同)

一、概述 随着新一代信息技术在产业数字化中的应用,产生了大量多源多模态信息以及响应的信息处理模式,数据孤岛、模型林立的问题也随之产生,使得业务系统臃肿、信息处理和决策效率低下,面对复杂任务及应用场景问题求解效率低。针…

MySQL__三大日志

文章目录 😊 作者:Lion J 💖 主页: https://blog.csdn.net/weixin_69252724 🎉 主题:Redis__三大日志 ⏱️ 创作时间:2024年04月30日 ———————————————— 对于MySQL来说, 有…