网站首页 > 技术文章 正文
数组追加元素指的是在数组末尾追加新的元素。数组插入元素指在数组中选择任意位置插入新的元素。实现数组插入元素,首先定义结构体数据类型
struct Arr{
int *pBase;//存储数组第一个元素的地址
int len;//存储数组最大元素个数
int cnt;//当前数组有效元素个数
};
接下来需要考虑函数的定义
插入元素成功后返回true,失败返回false,所以使用返回值bool。函数的参数从以下几方面考虑
(1)使用指针操作结构体中的数组地址,所以需要传入结构体指针
(2)插入元素因为需要选择在某个元素之前插入,所以需要传入插入的位置
(3)具体插入元素的值
函数的声明如下
bool insert_arr(struct Arr *pArr, int pos, int val)
其中有3个形参
(1)struct Arr *pArr是结构体指针,可以操作结构体中的成员变量
(2)int pos是插入元素的位置
(3)int val是插入元素的值
最后就要思考这个函数怎么写
先来考虑插入操作。函数传入的参数中有pos表示位置,插入的定义:在这个位置之前插入数据(位置从1开始)。如
数组元素 | 10 | 20 | 30 | 40 |
对应位置 | 1 | 2 | 3 | 4 |
位置3插入元素666,即
数组元素 | 10 | 20 | 666 | 30 | 40 |
对照上述两个数组可以发现,插入数据可以从数组中的最后一个元素开始,依次后移,再将数据插入即可。如果要将数据依次后移,需要用到循环,此时需要确定的是for循环中的循环参数设置。
示例:数组a,数组长度5,有效元素个数5
位置编号从1开始
数组下标从0开始
包含5个元素10、20、30、40、50。
元素值 | 10 | 20 | 30 | 40 | 50 |
数组下标 | [0] | [1] | [2] | [3] | [4] |
位置编号 | 1 | 2 | 3 | 4 | 5 |
假设在位置3,插入数据666,使用for循环:
(1)循环初始值,i的初值为数组的最后一个元素,最后一个元素位置是5,下标是4,i=pArr->cnt-1
(2)循环变量,循环的最后一个元素,插入位置是3,下标为2,所以移动的最后一个元素的位置i>=pos-1
(3)循环步长,数组从最后一个元素开始循环,所以是递减,i--
因此循环可以完成将元素移动的操作,如下:
for(i = pArr->cnt-1;i>=pos-1;i++)
循环中需要进行赋值操作,相当于依次将前一个值赋给后一个值(也可以理解为将第1个值赋给第2个值)
pArr->pBase[i+1] = pArr->pBase[i];
最后在指定位置插入值
pArr->pBase[pos-1] = val;
数组的有效元素个数加1
pArr->cnt++;
当然还需要考虑几种情况:
(1)数组满
(2)传入位置的数值非法(如:负数)
(3)传入位置数值越界
所以需要使用条件进行判断。如下是全部代码示例
bool insert_arr(struct Arr *pArr, int pos, int val){
int i = 0;
if(is_full(pArr))
return false;
if(pos < 1 || pos > pArr->cnt + 1)
return false;
for(i = pArr->cnt-1; i >= pos - 1; i--)
pArr->pBase[i+1] = pArr->pBase[i];
pArr->pBase[pos-1] = val;
pArr->cnt++;
return true;
}
猜你喜欢
- 2024-09-08 「JavaScript 从入门到精通」10.数组
- 2024-09-08 JS——数组的方法 & 高阶函数
- 2024-09-08 Javascript中的内置对象—数组(javascript内置对象应用的)
- 2024-09-08 js数组方法笔记(js的数组)
- 2024-09-08 JavaScript 数组元素的一些操作(javascript中数组)
- 2024-09-08 Javascript数组应用及场景——创建数组的N种方式详解
- 2024-09-08 详解JS数组API方法重构(js 数组 api)
- 2024-09-08 手把手教你Javascript (6)-数组(javascript10分钟速成)
- 2024-09-08 JS核心基础数组的操作概述(js数组原理)
- 2024-09-08 JavaScript操作数组的方式都有哪些
- 1517℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 594℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 521℃MySQL service启动脚本浅析(r12笔记第59天)
- 489℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 489℃启用MySQL查询缓存(mysql8.0查询缓存)
- 477℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 456℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 454℃MySQL server PID file could not be found!失败
- 最近发表
-
- PS所有滤镜的说明(六)(ps滤镜详解)
- 5款小白也能用的在线图片编辑器!电商效率飙升就靠它!
- Java变量(java变量有什么作用)
- Java面试常见问题:Java注解(java中的面试题)
- Java编程入门第一课:HelloWorld(java编程从入门到实践)
- Java基础教程:Java继承概述(java里继承的概述)
- java基础之——访问修饰符(private/default/protected/public)
- 如何规划一个合理的JAVA项目工程结构
- 将机器指令翻译成 JavaScript -- 终极目标
- Web 服务器基准测试:Go vs. Node.js vs. Nim vs. Bun
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)