结构 数组

1.结构数组的定义        

        在C语言中,可以将数组定义为结构类型,他与普通数组的不同之处是结构数组的每一个元素都是一个结构类型的数据。

有以下三种定义方式

(1)先声明结构类型,再定义结构数组,格式如下:

struct结构名
{
    成员列表;
};
struct 结构名 数组名[元素个数][,数组名[元素个数],…];

(2)声明结构类型的同时定义结构数组,格式如下:

struct 结构名
{
成员列表;
}数组名[元素个数][,数组名[元素个数],…];

(3)直接定义结构数组,格式如下:

struct
{
    成员列表;
}数组名[元素个数][,数组名[元素个数],…];

让我们来简单定义一个结构数组

struct books
{
    int bno;
    char bname[20];
    char field[10];
    char author_[10];
    char publisher_[30];
    float price;
};
struct books book[5];

结构数组 book 共有5个元素,book[0]~book[4],每个数组元素都具有 struct books的结构类型。

2.结构数组的初始化

        结构数组在定义的同时也可以初始化,可进行部分初始化或全部初始化。结构数组初始化的一般形式为
 

struct 结构名 数组名[元素个数] = {初值表列};

        (1)在对结构数组进行初始化时,需遵循数组的初始化规律,可对其中的部分数组元素初始化,但是对结构数组元素中的每个成员都要进行初始化。

        (2)在对结构数组进行全部初始化时,初值的个数应当与结构数组的元素个数以及每个数组元素的成员个数相匹配。为了增强程序的可读性,最好用大括号将每一个数组元素的初值括起来。
        (3)当对结构数组的全部元素进行初始化时,可以省略数组的长度,系统根据初始化数据的多少来确定数组的长度。

3.结构数组的使用

        结构数组的使用也是通过引用结构数组元素的成员进行的。结构数组元素中成员的访问方法与结构变量成员的访问方法类似,通过成员运算符“.”来引用。另一方面,由于可以通过数组名以指针法形式来引用数组元素,因此对于结构数组元素成员的引用可以有如下几种形式:
(1)结构数组名[下标].成员名

(2)(*(结构数组名十下标)).成员名

(3)(结构数组名十下标)一>成员名

下面来进行实例运用

#include<stdio.h>
struct books    /*结构类型*/
{
    int bno;
    char bname[20],field[10],author[10],publisher[30];
    float price;
};
int main( )
{
struct books book[5]={
(101 , "clanguage" ,"computer" ,"xw","rmydpress" ,39},
{102, "vbprogramming" ,"computer" ,"zys" ,"qhdxpress" ,39};
{103 , "java" ,"computer","mj" ,"jxgypress" ,34},
(104 , "linearalgebra" ," math" ,"chc" ,"dzgypress" ,29.8),
{105, "clanguage" ,"computer" ,"thq" ,"qhdxpress" ,26}
};
printf(" %s\t%.2f\n" ,book[2]. bname,book[2].price+10);
printf("%s\t%.2f\n",(*(book+2)).bname,(*(book+2)),price+10);
printf("%s\t%.2f\n",(book+2)->bname,(book+2)->price+10);
return O;
}

        在实际应用中,结构数组也可以作为函数的参数,在函数间传递的是结构数组的首地址。即结构数组名作为函数的实参传递给对应的形参,实参和形参指向同一段内存空间,如被调用函数中改变了形参结构数组某个元素的成员值,则相应的实参结构数组元素的值也会发生改变。

我们来尝试一下结构数组作为函数参数的实例

#include<stdio. h>
struct ss( int a; int b; };
void fun(struct ss m[ ], int n)
{    int i,j,k;
struct ss temp;
for(i=0;i<n-1;i++)
{
     k=i;
for(j=i+1;j<n;j++)
if((m [j].a<m[k].a)||(m[j].a==m[k].a&.&m[j].b<m[k].b))
    k=j;
if(k!=i)
{    temp=m[i];m[i]=m[k];m[k]= temp;}

int main()
{
struct ss x[]={(5,3},{3,2},{3,6},(2,4},(5,8}};
int i,k=5;
fun(x,k);
for(i=0;i<k;i++)
printf("%d, %d\n",x[i].a, x[i].b);
return0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值