您的位置 首页 java

数据结构-数组实现-初始化

数组是一类数据的集合,利用数组可以实现数据的存储,但 如何实现数组

一、利用结构体定义数据类型

数组是一种数据结构,需要利用结构体定义数据的类型,对于一个数组,需要知道 数组的首元素的地址、数组长度、数组中的有效个数

 struct Arr{
	int *pBase;//存储数组第一个元素的地址
	int len;//存储数组最大元素个数
	int cnt;//当前数组有效元素个数
};  

二、数组初始化函数声明

定义结构体struct Arr,进行结构体变量声明

struct Arr arr;

在这个过程中,声明的结构体变量arr中的3个成员pBase、len、cnt存储的是内存中的垃圾值,需要对其进行初始化,定义初始化函数init_arr()。

需要考虑几个问题

(1) 返回值 。对于初始化,仅需要将结构体中各参数初始化不需要返回值,因此是 void

(2) 参数 。初始化函数中需要传入的参数。

首先考虑,如果传入的是结构体变量,相当于是将声明的结构体变量赋值给初始化函数,并不能修改主函数中结构体变量的各个成员的值,不能达到初始化的效果,因此 需要传入的是结构体指针变量

然后考虑,数组中的成员并不是不变的,因此初始化中可以 传入数组的长度

所以初始化的函数声明如下:

 void init_arr(struct *pArr, int length);  

三、数组初始化函数定义

函数定义是指函数需要实现的功能。数组初始化函数对数组分配内存、初始化数组长度以及初始化数组有效元素个数。

为数组分配内存,使用malloc()函数

 pArr->pBase = (int *)malloc(sizeof(length) * length);  

初始化数组的长度

 pArr->len = length;  

初始化数组有效个数

 pArr->cnt = 0;  

但在初始化过程中有可能出现 内存分配失败 的情况,因此采用 if语句进行判断 ,判断 malloc()函数返回值是否为空 ,具体代码如下

 void init_arr(struct Arr *pArr, int length){
	//为数组动态分配内存
	pArr->pBase = (int *)malloc(sizeof(length) * length);
	//返回空指针,结束函数
	if(NULL == pArr->pBase){
		printf("动态内存分配失败");
		exit(-1);
	}
	else{
		pArr->len = length;
		pArr->cnt = 0;
	}
	return;
}  

文章来源:智云一二三科技

文章标题:数据结构-数组实现-初始化

文章地址:https://www.zhihuclub.com/187661.shtml

关于作者: 智云科技

热门文章

发表回复

您的电子邮箱地址不会被公开。

网站地图