数据结构【动态数组】

这篇具有很好参考价值的文章主要介绍了数据结构【动态数组】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据结构【动态数组】

在堆中申请数组空间,扩容时realloc,注意不可增删改的情况并处理即可。

以下代码不一定完全正确。文章来源地址https://www.toymoban.com/news/detail-749242.html

#include <stdio.h>
#include <stdlib.h>

/**
 * 声明动态数组,并提供相关的函数操作
 */


// 动态数组结构体
typedef struct Array
{

    // 动态数组
    int *elementData;

    // 容量
    size_t capacity;

    // 长度
    size_t size;

} DynamicArray;



// 初始化动态数组
void initDynamicArray(DynamicArray *array, size_t initialCapacity);
// 释放动态数组内存
void destroyDynamicArray(DynamicArray *array);
// 调整动态数组内存大小
void resizeDynamicArray(DynamicArray *array, size_t newCapacity);
// 获取动态数组长度(元素个数)
size_t getLength(const DynamicArray *array);
// 在指定位置插入新元素
void insertAt(DynamicArray *array, size_t index, int element);
// 在末尾插入新元素
void insertEnd(DynamicArray *array, int element);
// 删除指定位置的元素并返回被删除的元素
int deleteAt(DynamicArray *array, size_t index);
// 删除末尾的元素并返回被删除的元素
int deleteEnd(DynamicArray *array);
// 遍历所有的元素
void print(DynamicArray *array);


/**
 * 主函数
*/
int main(int argc, char const *argv[])
{
    DynamicArray array;
    initDynamicArray(&array, 2);
    insertAt(&array, 0, 10);
    insertAt(&array, 0, 20);
    insertAt(&array, 0, 20);
    print(&array);


    getchar();
    return 0;
}


// 初始化动态数组
void initDynamicArray(DynamicArray *array, size_t initialCapacity){

    // 分配空间
    if (initialCapacity > 0) {
        array->elementData = (int *) malloc(initialCapacity * (sizeof(int)));
    } else if (initialCapacity == 0) {
        array->elementData = NULL;
    } else {
        printf("您输入的长度不合法。");
        return;
    }

    // 初始化capacity
    array->capacity = initialCapacity;

    // todo 初始化size
    array->size = 0;
}
// 释放动态数组内存
void destroyDynamicArray(DynamicArray *array){
    free(array->elementData);
}

// 扩容
void resizeDynamicArray(DynamicArray *array, size_t newCapacity){
    printf("1.5倍扩容启动\n");
    array->elementData = realloc(array->elementData, newCapacity*sizeof(int));
    array->capacity += array->capacity>>1;
}

// 获取动态数组长度(元素个数)
size_t getLength(const DynamicArray *array){
    return array->size;
}

// 在指定位置插入新元素
void insertAt(DynamicArray *array, size_t index, int element){
    // index 不符合规则的情况
    if(index < 0 || index > array->size){
        printf("无效的位置输入\n");
        return;
    }
    (array->size == array->capacity) ? resizeDynamicArray(array, array->capacity += array->capacity>>1) : 0;
    //
    for(int i = array->size; i>index; i--){
        array->elementData[i] = array->elementData[i-1];
    }
    array->elementData[index] = element;
    array->size++;
}

// 在末尾插入新元素
void insertEnd(DynamicArray *array, int element){
    insertAt(array, array->size, element);
}

// 删除指定位置的元素并返回被删除的元素
int deleteAt(DynamicArray *array, size_t index){
    if(index < 0 || index >= array->size){
        printf("无效的元素删除\n");
        return -1;
    }
    int temp = array->elementData[index];
    for(int i = index+1; i<array->size; i++){
        array->elementData[i-1] = array->elementData[i];
    }
    array->size--;
    return temp;
}

// 删除末尾的元素并返回被删除的元素
int deleteEnd(DynamicArray *array){
    return deleteAt(array, array->size-1);
}

// 遍历所有的元素
void print(DynamicArray *array){
    for(int i = 0; i<array->size; i++){
        printf("%d\n", array->elementData[i]);
    }
    printf("\n");
}

到了这里,关于数据结构【动态数组】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JavaSE专栏48】Java集合类ArrayList解析,这个动态数组数据结构你了解吗?

    作者主页 :Designer 小郑 作者简介 :3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。 主打方向 :Vue、SpringBoot、微信小程序 本文讲解了 Java 中集合类 ArrayList 的语法、使用说明和应用场景,并给出了样例代码。

    2024年02月16日
    浏览(50)
  • DSt:数据结构的最强学习路线之数据结构知识讲解与刷题平台、刷题集合、问题为导向的十大类刷题算法(数组和字符串、栈和队列、二叉树、堆实现、图、哈希表、排序和搜索、动态规划/回溯法/递归/贪心/分治)总

    Algorithm:【算法进阶之路】之算法面试刷题集合—数据结构知识和算法刷题及其平台、问题为导向的十大类刷题算法(数组和字符串、链表、栈和队列、二叉树、堆、图、哈希表、排序和搜索、回溯算法、枚举/递归/分治/动态规划/贪心算法)总结 目录 相关文章

    2024年02月08日
    浏览(43)
  • 数据结构——线性数据结构(数组,链表,栈,队列)

    数组(Array) 是一种很常见的数据结构。它由相同类型的元素(element)组成,并且是使用一块连续的内存来存储。 我们直接可以利用元素的索引(index)可以计算出该元素对应的存储地址。 数组的特点是: 提供随机访问 并且容量有限。 2.1. 链表简介 链表(LinkedList) 虽然是

    2024年02月11日
    浏览(33)
  • 【算法 & 高级数据结构】树状数组:一种高效的数据结构(一)

    🚀 个人主页 :为梦而生~ 关注我一起学习吧! 💡 专栏 :算法题、 基础算法~赶紧来学算法吧 💡 往期推荐 : 【算法基础 数学】快速幂求逆元(逆元、扩展欧几里得定理、小费马定理) 【算法基础】深搜 树状数组 (Binary Indexed Tree,BIT)是一种数据结构,用于高效地处理

    2024年03月11日
    浏览(52)
  • 【算法 & 高级数据结构】树状数组:一种高效的数据结构(二)

    🚀 个人主页 :为梦而生~ 关注我一起学习吧! 💡 专栏 :算法题、 基础算法、数据结构~赶紧来学算法吧 💡 往期推荐 : 【算法基础 数学】快速幂求逆元(逆元、扩展欧几里得定理、小费马定理) 【算法基础】深搜 数据结构各内部排序算法总结对比及动图演示(插入排序

    2024年03月26日
    浏览(75)
  • 线性数据结构:数组、受限数组(栈、队列)、线性表

      数组(Array)是有序的元素序列。属于线性结构(有且仅有一个前驱、有且仅有一个后继)。   数组的关键在于在内存中的物理地址对应的是 一段连续的内存 。这意味着如果想要在任意位置删除/新增一个元素,那么该位置往后的所有元素,都需要往前挪/往后挪一个位

    2024年03月09日
    浏览(42)
  • 数据结构<1>——树状数组

    前言:树状数组能解决的问题线段树一定可以解决。然后关于线段树的内容会在2中讲解。 树状数组,也叫Fenwick Tree和BIT(Binary Indexed Tree),是一种支持 单点修改 和 区间查询 的,代码量小的数据结构。 那神马是单点修改和区间查询?我们来看一道题。 洛谷P3374(模板): 在本题中

    2024年01月25日
    浏览(50)
  • 基础数据结构:数组介绍

    程序设计 = 数据结构+算法 说到数据结构是什么,我们得先来谈谈什么叫数据。 正所谓\\\"巧妇难为无米之炊’,再强大的计算机,也是要有\\\"米’下锅才可以的,否则就是一堆破铜烂铁 这个\\\"米\\\"就是数据。 数据: 是描述客观事物的符号,是计算机中可以操作的对象,是能被计算

    2024年02月11日
    浏览(37)
  • 数据结构基础-数组

    概述 定义 在计算机科学中,数组是由一组元素(值或变量)组成的数据结构,每个元素有至少一个索引或键来标识 In computer science, an array is a data structure consisting of a collection of elements (values or variables), each identified by at least one array index or key 因为数组内的元素是 连续存储 的,

    2024年02月07日
    浏览(32)
  • 二维数组-数据结构

    二维数组可以定义为数组的数组。二维数组被组织为矩阵,可以表示为行和列的集合。 然而,创建二维数组是为了实现类似于关系数据库的数据结构。它可以轻松地一次保存大量数据,这些数据可以在需要时传递到任意数量的函数。 二维数组可视化在线操作-图码 数据结构可

    2024年01月18日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包