如何实现动态数组C的分享方法?

2026-05-19 23:311阅读0评论SEO教程
  • 内容介绍
  • 相关推荐

本文共计725个文字,预计阅读时间需要3分钟。

如何实现动态数组C的分享方法?

c// Array.h

#ifndef ARRAY_H#define ARRAY_H

#include

typedef struct { int *elements; // 指向数组元素的指针 size_t size; // 当前数组元素的数量 size_t capacity; // 数组的容量} Array;

// 初始化数组void Array_Init(Array *array, size_t initialCapacity);

// 销毁数组void Array_Destroy(Array *array);

如何实现动态数组C的分享方法?

// 添加元素到数组void Array_PushBack(Array *array, int element);

// 获取数组中的元素int Array_Get(const Array *array, size_t index);

// 获取数组的容量size_t Array_GetCapacity(const Array *array);

// 获取数组的当前大小size_t Array_GetSize(const Array *array);

#endif // ARRAY_H

回顾大二的数据结构知识。从数组开始。实现了一个可自动扩充容量的泛型数组。

头文件:Array.h

#ifndef Array_hpp #define Array_hpp template <class T> class Array{ private: T *base; //数组首地址 int length; //数组中元素 int size; //数组大小,以数组中元素的大小为单位 public: //初始化数组,分配内存 bool init(); //检查内存是否够用,不够用就增加 bool ensureCapcity(); //添加元素到数组尾 bool add(T item); //插入元素到数组的具体位置,位置从1开始 bool insert(int index,T item); //删除指定位置的元素并返回,位置从1开始 T del(int index); //返回指定位置的元素 T objectAt(int index); //打印数组所有元素 void display(); }; #endif /* Array_hpp */

实现:Array.cpp

#include "Array.hpp" #include <mm_malloc.h> #include <iostream> using namespace std; template<typename T> bool Array<T>::init(){ base = (T *)malloc(10*sizeof(T)); if(!base){ return false; } size = 10; length = 0; return true; } template<typename T> bool Array<T>::ensureCapcity(){ if(length >= size){ T *newBase = (T*)realloc(base,10 * sizeof(T) + size); if(!newBase){ return false; } base = newBase; size += 10; newBase = nullptr; } return true; } template<typename T> bool Array<T>::add(T item){ if(!ensureCapcity()){ return false; } T *p = base + length; *p = item; length ++; return true; } template<typename T> bool Array<T>::insert(int index,const T item){ if(!ensureCapcity()){ return false; } if(index < 1 || index > length){ return false; } T *q = base + index - 1; T *p = base + length - 1; while( p >= q){ *(p+1) = *p; p--; } *q = item; q = nullptr; p = nullptr; length ++; return true; } template<typename T>T Array<T>::del(int index){ if(index<1 || index > length){ return NULL; } T *q = base + index - 1; T item = *q; ++q; T *p = base + length; while(q <= p){ *(q-1)=*q; ++q; } length --; return item; } template<typename T>T Array<T>::objectAt(int index){ if(index<1 || index > length){ return NULL; } T *q = base; return *(q + index - 1); } template <typename T>void Array<T>::display(){ T *q = base; T *p = base +length - 1; while (q<=p) { cout << *(q++)<<" "; } cout << endl; }

使用:

#include <iostream> #include "Array.cpp" using namespace std; int main(int argc, const char * argv[]) { Array<int> array = *new Array<int>; array.init(); array.add(1); array.insert(1,2); array.objectAt(1); return 0; }

以上这篇动态数组C++实现方法(分享)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自由互联。

本文共计725个文字,预计阅读时间需要3分钟。

如何实现动态数组C的分享方法?

c// Array.h

#ifndef ARRAY_H#define ARRAY_H

#include

typedef struct { int *elements; // 指向数组元素的指针 size_t size; // 当前数组元素的数量 size_t capacity; // 数组的容量} Array;

// 初始化数组void Array_Init(Array *array, size_t initialCapacity);

// 销毁数组void Array_Destroy(Array *array);

如何实现动态数组C的分享方法?

// 添加元素到数组void Array_PushBack(Array *array, int element);

// 获取数组中的元素int Array_Get(const Array *array, size_t index);

// 获取数组的容量size_t Array_GetCapacity(const Array *array);

// 获取数组的当前大小size_t Array_GetSize(const Array *array);

#endif // ARRAY_H

回顾大二的数据结构知识。从数组开始。实现了一个可自动扩充容量的泛型数组。

头文件:Array.h

#ifndef Array_hpp #define Array_hpp template <class T> class Array{ private: T *base; //数组首地址 int length; //数组中元素 int size; //数组大小,以数组中元素的大小为单位 public: //初始化数组,分配内存 bool init(); //检查内存是否够用,不够用就增加 bool ensureCapcity(); //添加元素到数组尾 bool add(T item); //插入元素到数组的具体位置,位置从1开始 bool insert(int index,T item); //删除指定位置的元素并返回,位置从1开始 T del(int index); //返回指定位置的元素 T objectAt(int index); //打印数组所有元素 void display(); }; #endif /* Array_hpp */

实现:Array.cpp

#include "Array.hpp" #include <mm_malloc.h> #include <iostream> using namespace std; template<typename T> bool Array<T>::init(){ base = (T *)malloc(10*sizeof(T)); if(!base){ return false; } size = 10; length = 0; return true; } template<typename T> bool Array<T>::ensureCapcity(){ if(length >= size){ T *newBase = (T*)realloc(base,10 * sizeof(T) + size); if(!newBase){ return false; } base = newBase; size += 10; newBase = nullptr; } return true; } template<typename T> bool Array<T>::add(T item){ if(!ensureCapcity()){ return false; } T *p = base + length; *p = item; length ++; return true; } template<typename T> bool Array<T>::insert(int index,const T item){ if(!ensureCapcity()){ return false; } if(index < 1 || index > length){ return false; } T *q = base + index - 1; T *p = base + length - 1; while( p >= q){ *(p+1) = *p; p--; } *q = item; q = nullptr; p = nullptr; length ++; return true; } template<typename T>T Array<T>::del(int index){ if(index<1 || index > length){ return NULL; } T *q = base + index - 1; T item = *q; ++q; T *p = base + length; while(q <= p){ *(q-1)=*q; ++q; } length --; return item; } template<typename T>T Array<T>::objectAt(int index){ if(index<1 || index > length){ return NULL; } T *q = base; return *(q + index - 1); } template <typename T>void Array<T>::display(){ T *q = base; T *p = base +length - 1; while (q<=p) { cout << *(q++)<<" "; } cout << endl; }

使用:

#include <iostream> #include "Array.cpp" using namespace std; int main(int argc, const char * argv[]) { Array<int> array = *new Array<int>; array.init(); array.add(1); array.insert(1,2); array.objectAt(1); return 0; }

以上这篇动态数组C++实现方法(分享)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自由互联。