C高级编程 第十二天(动态数组)

2024-09-02 04:44

本文主要是介绍C高级编程 第十二天(动态数组),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.算法的特性:

2.数据结构的分类

2.1逻辑结构

2.2物理结构

3.动态数组

②动态数组初始化

③插入数组

④遍历数组

⑤删除数组

⑥销毁数组


1.算法的特性:

  • 输入输出
  • 有穷性
  • 确定性
  • 可行性

2.数据结构的分类

2.1逻辑结构

  • 集合结构
  • 线性结构
  • 树形结构
  • 图形结构

2.2物理结构

  • 顺序存储
  • 链式存储

3.动态数组

①结构体设计

struct dynamicArray
{void** pAddr;//在堆区开批数组的指针int m_Capacity;//能容纳多少int m_Size;	//当前存放所有数据的大小
};

②动态数组初始化

struct dynamicArray* initData(int capacity)
{struct dynamicArray* re = malloc(sizeof(struct dynamicArray));if (re == NULL){return NULL;}re->pAddr = malloc(sizeof(void*) * capacity);re->m_Capacity = capacity;re->m_Size = 0;return re;
}

③插入数组

void insert_Array(struct dynamicArray* a, void* data, int pos)
{if (a == NULL || data == NULL){return;}//空间满了if (a->m_Capacity == a->m_Size){int newCapacity = a->m_Capacity * 2;void** newSize = malloc(sizeof(void*) * newCapacity);memcpy(newSize, a->pAddr, a->m_Size);free(a->pAddr);a->pAddr = NULL;a->pAddr = newSize;a->m_Size = newCapacity;}for (int i = a->m_Size; i >= 0; i--){a[i + 1] = a[i];    //整体元素向后移}a->pAddr[pos] = data;a->m_Size++;
}

④遍历数组

void* printArray(struct dynamicArray* array)
{if (NULL == array){return;}for (int i = 0; i = array->m_Size; i++){printf("%d", array->pAddr[i]);}
}

⑤删除数组

通过下标删除:

void removeByPos(struct dynamicArray* a, int pos)
{if (a == NULL){return;}for (int i = pos; i <a->m_Size; i++){a[i] = a[i + 1]; }  a->m_Size--;
}

通过值删除:

void removeByValue(struct dynamicArray* a,void* data,int((*compare)(void*,void*)))
{if (a == NULL){return;}for (int i = 0; i = a->m_Size; i++){if (compare(a, data)){removeBypos(a, i);}}
}
int compare(void* data1, void* data2)
{struct dynamicArray* data11 = (struct dynamicArray*)data1;struct dynamicArray* data21 = (struct dynamicArray*)data1;return strcmp(data11->pAddr, data21->pAddr);
}

⑥销毁数组

void destory(struct dynamicArray* a)
{if (a == NULL){return;}if (a->pAddr == NULL){free(a->pAddr);a->pAddr = NULL;}free(a);a = NULL;
}

这篇关于C高级编程 第十二天(动态数组)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129022

相关文章

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu