你可能没听过的数组-----柔性数组

柔性数组其实是结构体中的最后一个数组未说明大小,且结构体中至少包含一个以上其他类型,如

#include<stdio.h>

struct hei

{

int zeng;

char shi;

int arr[];//或者int arr[0];

}ma;

int main()

{

struct hei ma;

return 0

}

二、具体使用

======

1.用创建柔性数组的方法:


#include<stdio.h>

#include<stdlib.h>

#include<stdlib.h>//或者是#include<malloc.h>动态内存函数的头文件

struct d

{

int nb;

int nn;

int arr[];

};

int main()

{

struct d p=(struct d)malloc(sizeof(struct d)+5*sizeof(int));//分别给结构体中的除了柔

//性数组的其他类型和给柔性数组申请空间

p->nb=100;

p->nn=50;

for(int i=0;i<5;i++)

{

p->arr[i]=i;//赋值

printf("%d ",p->arr[i]);

}

struct d pp=(struct d)realloc(p,48); //重新调整所申请的空间,将柔性数组调整为40。

if(pp!=NULL)

{

p=pp;

for(i=5;i<10;i++)

{

p->arr[i]=i;//赋值

printf("%d ",p->arr[i]);

}

free§;

p=NULL;

}

return 0;

}

2.用普通的写法


#include<stdio.h>

#include<stdlib.h>

struct bb

{

int a;

int *arr;

};

int main()

{

struct bb* p=(struct
bb*)malloc(sizeof(struct bb));

p->a=20;

p->arr=(int*)malloc(5*sizeof(int));

for(int i=0;i<5;i++)

{

p->arr[i]=i;

printf("%d ",p->arr[i]);

}

int ptr=(int)realloc(p->arr,40);

if(pp!=NULL)

{

p->arr=ptr;

for(int i=5;i<10;i++)

{

int t=p->arr[i]=i;

printf("%d ",t);

}

}

free(p->arr);

p->arr=NULL;

free§;

p=NULL;

return 0;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值