ESP-IDF:在C++环境下实现动态数组例程,包括初始化,添加数值,查找,删除,打印等功能

news2025/1/11 9:50:49

代码:

/* 动态数组 */
struct DYNAMICARRAY
{
int *pAddress;
int size;
int capacity;
};

DYNAMICARRAY *initialDynamicArray()
{
DYNAMICARRAY *p = (DYNAMICARRAY *)malloc(sizeof(DYNAMICARRAY));
p->size = 0;
p->capacity = 5;
p->pAddress = (int *)malloc(sizeof(int) * p->capacity);
return p;
}

void push_back(DYNAMICARRAY *p, int b)
{
if (p == NULL)
{
return;
}
if (p->size == p->capacity)
{
int *newArray = (int *)malloc(sizeof(int) * p->capacity * 2);
for (int i = 0; i < p->size; i++)
{
newArray[i] = p->pAddress[i];
}
free(p->pAddress);
p->capacity = p->capacity * 2;
p->pAddress = newArray;
}

p->pAddress[p->size] = b;
p->size++;

}

void print_arrary(DYNAMICARRAY *p)
{
if (p == NULL)
{
return;
}
for (int i = 0; i < p->size; i++)
{
cout << p->pAddress[i] << endl;
}
cout << “mArray size=” << p->size << endl;
cout << “mArray capcitory” << p->capacity << endl
<< endl;
}

void free_mArray(DYNAMICARRAY *p)
{
if (p == NULL)
{
return;
}
free(p->pAddress);
free§;
p = NULL;
}

int find_mArray_by_value(DYNAMICARRAY *p, int b)
{
if (p == NULL)
{
return -1;
}
int pos = -1;
for (int i = 0; i <= p->size; i++)
{
if (b == p->pAddress[i])
{
pos = i;
// cout << “in find_mArray_by_value”
// << “i=” << i << " pos=" << pos << endl;
break;
}
if (i == p->size)
{
cout << “can’t find_mArray_by_value” << endl
<< endl;
break;
}
}
return pos;
}

void remove_by_value_in_array(DYNAMICARRAY *p, int b)
{
if (p == NULL)
{
return;
}
int pos = find_mArray_by_value(p, b);
for (int i = pos; i <= p->size; i++)
{
if (i == p->capacity)
{
p->pAddress = NULL;
p->size -= 1;
break;
}
p->pAddress[i] = p->pAddress[i + 1];
}
p->size -= 1;
}

void remove_by_position_in_array(DYNAMICARRAY *p, int b)
{
if (p == NULL)
{
return;
}
int pos = b;
for (int i = pos; i <= p->size; i++)
{
if (i == p->capacity)
{
p->pAddress = NULL;
p->size -= 1;
break;
}
p->pAddress[i] = p->pAddress[i + 1];
}
p->size -= 1;
}

void test07()
{
DYNAMICARRAY *mArry = initialDynamicArray();
cout << “--------print mArray before any change--------” << endl;
print_arrary(mArry);
for (int i = 0; i < 15; i++)
{
push_back(mArry, i);
}
cout << “--------print mArray after insert 0~15 --------” << endl;
print_arrary(mArry);

cout << "--------查找数值8,在动态数组中的位置 --------" << endl;
int val = 8;
int pos = 0;
pos = find_mArray_by_value(mArry, val);
cout << "value:" << val << " at pos " << pos << endl
     << endl;

cout << "--------删除数值9--------" << endl;
remove_by_value_in_array(mArry, 9);
print_arrary(mArry);

cout << "--------删除位置0上的数值--------" << endl;
remove_by_position_in_array(mArry, 0);
print_arrary(mArry);

free_mArray(mArry);

}

extern “C” void app_main(void)
{
test07();
}

结果:

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

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

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

相关文章

数据结构与算法--python版-01

文章目录基本概念数据存储方式算法案例基本概念 程序 数据结构 算法 数据结构&#xff0c;数据的存储&#xff08;物理结构&#xff09;及相互间的关联关系(逻辑结构)&#xff1b; 线性表&#xff08;顺序表、链表、队列、栈&#xff09;&#xff0c;一个前驱&#xff0c;一…

口语语言理解最新进展及前沿

口语语言理解 作为任务型对话系统的核心组件&#xff0c;目的是为了获取用户询问语句的框架语义表示信息&#xff0c;进而将这些信息为对话状态的追踪模块DSTDSTDST, 以及自然语言生成模块NLGNLGNLG所使用 SLUSLUSLU任务通常包含以下两个任务: 意图识别任务: intent detectio…

企企购商城 | 破解降本难题,非生采购“利器”来了

近年来&#xff0c;疫情反复无常&#xff0c;全球市场环境动荡不安&#xff0c;在瞬息万变的环境下&#xff0c;很多企业都处于降本处境&#xff0c;采购降本成了其中的重要一环。其中&#xff0c;非生采购作为贯穿企业各个职能板块的采购活动&#xff0c;众多国际先进的企业已…

应用PID算法对ABS系统的仿真和分析

1、内容简介略635-论文V2 可以交流、咨询、答疑2、内容说明摘要&#xff1a;本文旨在设计一种利用模糊控制理论优化的pid控制器&#xff0c;控制abs系统&#xff0c;达到对滑移率最佳控制范围的要求 &#xff0c;所提出的方案采用级联控制架构&#xff1a;设计用于外环中的车轮…

零基础开始QT绘图(6)

前面我们开始提到了GraphicView的使用&#xff0c;也提到GraphicsItem的使用&#xff0c;并且开始了自定义GraphicsItem的编写&#xff0c;而且上次我们的GraphicsItem也是可以拖动了&#xff0c;但这离我们需要的效果还有一定的距离。 所以&#xff0c;这次&#xff0c;我们进…

工程电磁设备在2018年杭州电磁大会的报告

1 方法原理 本篇是对多频电磁方法,应用的解读。 本汇报讲述了EMI传感器的基本情况,以及用手持多频电磁仪进行实际探测应用的例子。 什么是电磁感应?用发射装置(TX)激发谐波,产生一次场(Primary field),地下导体目标会相应产生涡流电磁场,产生二次场,被接收装置(RX…

「网络安全渗透」如果你还不懂CSRF?这一篇让你彻底掌握

1 什么是 CSRF 面试的时候的著名问题&#xff1a;"谈一谈你对 CSRF 与 SSRF 区别的看法" 这个问题&#xff0c;如果我们用非常通俗的语言讲的话&#xff0c;CSRF 更像是钓鱼的举动&#xff0c;是用户攻击用户的&#xff1b;而对于 SSRF 来说&#xff0c;是由服务器…

14.0、Linux-yum方式安装 docker

14.0、Linux-yum方式安装 docker 第一步&#xff1a; 检测 CentOS7 -> cat /etc/redhat-release 第二步&#xff1a; 用以下命令安装准备环境 -> yum -y install gcc yum -y install gcc-c 第三步&#xff1a; 如果之前安装过 docker 的&#xff0c;先用以下命令删…

【每日一题】【LeetCode】【第十三天】移动零

解决之路 题目描述 测试案例&#xff08;部分&#xff09; 第一次 看到这题目&#xff0c;第一时间还真想到了双指针法&#xff08;暴力解法是个会写代码的都能第一时间想到&#xff0c;所以自己学会了尽量不第一时间用暴力解法&#xff09; right的初始位置元素若为0&…

Jenkins-Slave分布式架构搭建

♥ Jenkins的分布式构建&#xff0c;在Jenkins的配置中叫做节点&#xff0c;分布式构建能够让同一套代码或项目在不同的环境(如&#xff1a;Windows和Linux系统)中编译、部署等。 ♥ 将jenkins项目发布在不同服务器上&#xff08;分布jenkins工作空间&#xff0c;部署项目到不同…

java 简单了解spring之(IOC容器)

IOC 容器 是spring的一个重要组成部分 IOC 翻译过来叫控制反转 他在做的事是 降低计算机代码的耦合度 这个过程叫IOC 通过控制反转 对象在被创建时 由一个调控系统内所有对象的外界实体将将其所依赖的对象引用传递给他&#xff0c;也可以说&#xff0c;依赖被注入到对象中 说简…

[oeasy]python0048_取整_int_float_浮点型_cast_扮演_tab_制表键_制表符

转化为10进制 回忆上次内容 上次 把其他进制 转化回 十进制 用的是 int 函数 int 来自于 integer 同源词 还有 integrateentire意思都是完整的 完整的 和 零散的 相对 可以把 零散的小数 转化为 完整的整数吗&#xff1f;&#x1f914; 取整 可以 把一个浮点型的小数 取…

【Proteus仿真】【51单片机】酒精浓度检测系统设计

文章目录一、功能简介二、软件设计三、实验现象联系作者一、功能简介 本项目使用Proteus8仿真51单片机控制器&#xff0c;使用LCD1602显示模块、按键模块、LED和蜂鸣器、MQ-3酒精传感器模块等。 主要功能&#xff1a; 系统运行后&#xff0c;LCD1602显示酒精浓度值和阈值&…

【自学Docker】Docker命令

Docker命令 Docker命令分类 Docker环境信息 docker [info|version]Docker容器生命周期管理 docker [create|exec|run|start|stop|restart|kill|rm|pause|unpause]Docker容器操作运维 docker [ps|inspect|top|attach|wait|export|port|rename|stats]Docker容器rootfs命令 …

AMBA--AHB总线协议学习及Verilog实现与仿真(一)

1、AHB总线概述 AHB&#xff1a;Advanced High-performance Bus,即高级高性能总线。AHB总线是SOC芯片中应用最为广泛的片上总线。下图是一个典型的基于AMBA AHB总线的微控制器系统&#xff1a; 基于AMBA AHB的设计中可以包含一个或多个总线主机&#xff0c;通常一个系统里至少…

MySQL——如何正确的显示随机消息

在之前的文章中有介绍order by语句的几种执行模式。考虑如下场景&#xff1a;有一个APP&#xff0c;有一个随机显示英语单词的功能&#xff0c;也就是根据每个用户的级别有一个单词表&#xff0c;然后这个用户每次访问首页的时候&#xff0c;都会随机滚动显示三个单词。会发现随…

PhotoZoom2023专业的图片无损放大软件最新V8版功能介绍

PhotoZoom 8 全新版本 震撼来袭。 一款划时代的、技术上产生革命性影响的数码图片放大工具。 我们获取图片的方法&#xff0c;一般是从度娘图片和各个图库里找素材。但一般网上搜索到的很多图片像素都非常小&#xff0c;普通方法放大就像打了马赛克一样&#xff0c;根本没法直接…

基于STM32的室内环境监测系统、基于STM32的智能家居系统

程序源码无删减 整个开发用到的所有资料如下&#xff1a; 开发软件MDK JLINK驱动安装包及相关文件 stm32开发资料-stm32f103c8t6 PCtoLCD2002 取模软件 stm32配套的液晶屏资料以及相关程序 Stm32f103c8t6 UCOSII 各传感器的数据手册以及程序、BMP180、DHT11温度模块、HC-SR04 …

EthernetOnTCP--基于Qt QSslSocket 套接字在PCAP 集线器上实现以太网隧道

在上一篇文章中&#xff0c;我们使用PCAP建立了本地的软件集线器&#xff08;Hub&#xff09;。考虑到较远距离的跨车间调试&#xff0c;有必要使用Tcp连接构造一个以太网的隧道&#xff0c;使得两个车间之间的调试设备可以虚拟的连接在一个Hub上。当然&#xff0c;我们可以使用…

【ROS】—— 机器人系统仿真 —Rviz中控制机器人模型运动与URDF集成Gazebo(十五)

文章目录前言1. Arbotix使用流程1.1 安装 Arbotix1.2 创建新功能包&#xff0c;准备机器人 urdf、xacro 文件1.3 添加 Arbotix 配置文件1.4 编写 launch 文件配置 Arbotix1.5 启动 launch 文件并控制机器人模型运动2. URDF集成Gazebo2.1 URDF与Gazebo基本集成流程2.2 URDF集成G…