#include
#include
typedef struct _SoftArray{
int len;
int array[];
}SoftArray;
//打印输出斐波那契数列
void printfln(SoftArray *p,int len)
{
int i;
for(i=0;iarray[i]);
}
}
//动态生成斐波那契数列
void create(int len)
{
int i;
SoftArray * p=(SoftArray*)malloc(sizeof(SoftArray)+sizeof(int)*len); //声明结构体指针p,动态申请内存,大小为结构体大小+10个int型大小
for(i=0;iarray[i] = 1;
}else if( i >= 2 )
{
p->array[i] = p->array[i-1] + p->array[i-2];
}else
{
printf("DAMAGE: before Normal block or after Normal block");
return (-1);
}
}
printfln(p,len);
free(p);
}
//主函数
int main()
{
int i=0;
int len;
printf("请输入生成斐波那契数列的行数:");
scanf("%d",&len);
create(len);
return 0;
}