不知道哪里出错了。。
//main.c
#include<stdio.h>
#include"array.h"
int main()
{
Array a=array_create(50);
int i;
for(i=0;i<=100;i++){
*array_at(&a,i)=i;
}
printf("此时数组中有%d个元素\n",array_size(&a));
int cnt=0;
for(i=0;i<array_size(&a);i++,cnt++){
printf("%-3d",*array_at(&a,i));
if(cnt%5==0){
cnt=0;
printf("\n");
}
}
array_free(&a);
return 0;
}
//array.h
typedef struct{
int *array;
int size;
}Array;
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.c
#include"array.h"
#ifndef _ARRAY_H_
#define _ARRAY_H_
const BLOCK_size=20;
Array array_create(int init_size)
{
Array a;
a.array=(int*)malloc(sizeof(int)*init_size);
a.size=init_size;
return a;
}
void array_free(Array *a)
{
free(a->array);
a->array=0;
a->size=0;
}
int array_size(const Array *a)
{
return a->size;
}
int *array_at(Array *a,int index)
{
if(index>=a->size){
array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
}
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;
}
#endif
代码整体都是对的,唯一错误是69行
array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
第一个参数应该是a,不是&a,因为a已经是Array * 类型了啊,你干嘛又取地址呢?
(1)array_inflate函数的第一个参数类型错误,改成
void array_inflate(Array **a,int more_size);
(2)BLOCK_size没有声明类型,改成:
const int BLOCK_size=20; //这里补充类型
(3)ifndef define endif 这个应该写在.h文件中
代码修改如下:
//main.c
#include<stdio.h>
#include"array.h"
int main()
{
Array a=array_create(50);
int i;
for(i=0;i<=100;i++){
*array_at(&a,i)=i;
}
printf("此时数组中有%d个元素\n",array_size(&a));
int cnt=0;
for(i=0;i<array_size(&a);i++,cnt++){
printf("%-3d",*array_at(&a,i));
if(cnt%5==0){
cnt=0;
printf("\n");
}
}
array_free(&a);
return 0;
}
//array.h
#ifndef _ARRAY_H_
#define _ARRAY_H_
typedef struct{
int *array;
int size;
}Array;
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);
#endif
//array.c
#include"array.h"
#include <stdlib.h>
const int BLOCK_size=20; //这里补充类型
Array array_create(int init_size)
{
Array a;
a.array=(int*)malloc(sizeof(int)*init_size);
a.size=init_size;
return a;
}
void array_free(Array *a)
{
free(a->array);
a->array=0;
a->size=0;
}
int array_size(const Array *a)
{
return a->size;
}
int *array_at(Array *a,int index)
{
if(index>=a->size){
array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
}
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;
}
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!