结构 数组

1.结构数组的定义

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

有以下三种定义方式

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

cs 复制代码
struct结构名
{
    成员列表;
};
struct 结构名 数组名[元素个数][,数组名[元素个数],...];

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

cs 复制代码
struct 结构名
{
成员列表;
}数组名[元素个数][,数组名[元素个数],...];

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

cs 复制代码
struct
{
    成员列表;
}数组名[元素个数][,数组名[元素个数],...];

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

cs 复制代码
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.结构数组的初始化

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

cs 复制代码
struct 结构名 数组名[元素个数] = {初值表列};

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

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

(3)当对结构数组的全部元素进行初始化时,可以省略数组的长度,系统根据初始化数据的多少来确定数组的长度。

3.结构数组的使用

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

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

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

下面来进行实例运用

cs 复制代码
#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;
}

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

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

cs 复制代码
#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;
}
相关推荐
apocelipes2 小时前
Linux c 运行时获取动态库所在路径
linux·c语言·linux编程
int型码农3 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
学习噢学个屁5 小时前
基于STM32语音识别柔光台灯
c语言·stm32·单片机·嵌入式硬件·语音识别
XRZaaa10 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法
jie1889457586611 小时前
C++ 中的 const 知识点详解,c++和c语言区别
java·c语言·c++
彩妙不是菜喵12 小时前
算术操作符与类型转换:从基础到精通
c语言
JKHaaa14 小时前
几种简单的排序算法(C语言)
c语言·算法·排序算法
草莓熊Lotso17 小时前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM17 小时前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法
CodeOfCC18 小时前
c语言 封装跨平台线程头文件
linux·c语言·windows