c-可变数组

这节课有点复杂,最好看原课。。

可变数组

· 做一个大小可变的数组。

特点:

· 可以变大。

· 合适的大小。

· 可以访问各个元素。

创建一个函数库

· Array Array_create(int init_size);创建一个数组

· void array_free(Array *a);回收数组空间

· int array_size(const Array *a);告诉我们数组里有多少个空间可用

· int* array_at(Array *a,int index);访问数组单元

· void array_inflate(Array *a,int more_size);让数组“长大”。

Array_create

Array array_create(int init_size)
{
	Array a;
	a.array=(int*)malloc(sizeof(int*)init_size);
	a.size=init_size;
	return a;
} 

array_free

void array_free(Array *a)
{
	free(a->array);
	a->array=NULL;//保险起见。 
	a->size=0;
}

可变数组数据访问

int array_size(const Array *a)
{
	return a->size;
} //封装
int* array_at(Array *a,int index)
{
	return &(a->array[index]);
} 

可变数组自动增长

void array_inflate(Array *a,int more_size)
{
	int *p=(int*)malloc(sizeof(int)(a->size+more_size));
	int i;
	for(i=0;i<a->size;i++){
		p[i]=a->array[i]
	} 
	free(a->array);
	a->array=p;
	a->size+=more_size;
} 

代码仅供参考。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值