7.2 結(jié)構(gòu)體數(shù)組的定義和引用
單個(gè)的結(jié)構(gòu)體類(lèi)型變量在解決實(shí)際問(wèn)題時(shí)作用不大,一般是以結(jié)構(gòu)體類(lèi)型數(shù)組的形式出現(xiàn)。結(jié)構(gòu)體類(lèi)型數(shù)組的定義形式為:
struct stu /*定義學(xué)生結(jié)構(gòu)體類(lèi)型*/
{
char name[20]; /*學(xué)生姓名*/
char sex; /*性別*/
long num; /*學(xué)號(hào)*/
float score[3]; /*三科考試成績(jī)*/
};
struct stu stud[20]; /* 定義結(jié)構(gòu)體類(lèi)型數(shù)組stud ,*/
/ *該數(shù)組有2 0個(gè)結(jié)構(gòu)體類(lèi)型元素* /
其數(shù)組元素各成員的引用形式為:
stud[0].name 、stud[0].sex、stud[0].score[i];
stud[1].name、stud[1].sex、stud[1].score[i];
. . .
. . .
stud[19].name、stud[19].sex、stud[19].score[i];
[例7-1] 設(shè)某組有4 個(gè)人,填寫(xiě)如下的登記表,除姓名、學(xué)號(hào)外,還有三科成績(jī),編程實(shí)現(xiàn)對(duì)表格的計(jì)算,求解出每個(gè)人的三科平均成績(jī),求出四個(gè)學(xué)生的單科平均,并按平均成績(jī)由高分到低分輸出。
NumberNameEnglishMathemrPhysicsAverage
1Liping789876.
2Wanglin669086.
3Jiangbo897076.
4Yangming9010067.
題目要求的問(wèn)題多,采用模塊化編程方式,將問(wèn)題進(jìn)行分解如下:
1) 結(jié)構(gòu)體類(lèi)型數(shù)組的輸入。
2) 求解各學(xué)生的三科平均成績(jī)。
3) 按學(xué)生的平均成績(jī)排序。
4) 按表格要求輸出。
5) 求解組內(nèi)學(xué)生單科平均成績(jī)并輸出。
6) 定義m a i n ( )函數(shù),調(diào)用各子程序。
第一步,根據(jù)具體情況定義結(jié)構(gòu)體類(lèi)型。
struct stu
{
char name[20]; /*姓名* /
long number; /*學(xué)號(hào)* /
float score[4]; /* 數(shù)組依此存放English、Mathema、Physics,及Average*/
} ;
由于該結(jié)構(gòu)體類(lèi)型會(huì)提供給每個(gè)子程序使用,是共用的,所以將其定義為外部的結(jié)構(gòu)體類(lèi)型,放在程序的最前面。
第二步,定義結(jié)構(gòu)體類(lèi)型數(shù)組的輸入模塊。
void input(arr,n) /*輸入結(jié)構(gòu)體類(lèi)型數(shù)組arr 的n個(gè)元素*/
struct stu arr[];
int n;
{
int i,j;
char temp[30];
for (i=0;i {
printf("\ninput name,number,English,mathema,physic\n"); /*打印提示信息* /
gets(arr[i].name); /* 輸入姓名*/
gets(temp); /* 輸入學(xué)號(hào)*/
arr[i].number = atol(temp);
for(j = 0; j < 3; j++)
{
gets(temp); /*輸入三科成績(jī)* /
arr[i].score[j] = atoi(temp);
}
}
}
第三步,求解各學(xué)生的三科平均成績(jī)。
在結(jié)構(gòu)體類(lèi)型數(shù)組中第i個(gè)元素arr[i]的成員score的前三個(gè)元素為已知,第四個(gè)Average需計(jì)算得到。
void aver(arr,n)
struct stu arr[];
int n;
{
int i,j;
for(i=0;i {
arr[i].score[3] = 0;
for(j=0;j<3;j++)
arr[i].score[3]=arr[i].score[3]+arr[i].score[j]; /* 求和*/
arr[i].score[3]=arr[i].score[3] /3; /* 平均成績(jī)* /
}
}
第四步,按平均成績(jī)排序,排序算法采用冒泡法。
void order(arr,n)
struct stu arr[];
int n;
{
struct stu temp;
int i,j,x,y;
for(i = 0; i < n - 1; i++)
for( j = 0; j < n - 1 - i; j++)
單個(gè)的結(jié)構(gòu)體類(lèi)型變量在解決實(shí)際問(wèn)題時(shí)作用不大,一般是以結(jié)構(gòu)體類(lèi)型數(shù)組的形式出現(xiàn)。結(jié)構(gòu)體類(lèi)型數(shù)組的定義形式為:
struct stu /*定義學(xué)生結(jié)構(gòu)體類(lèi)型*/
{
char name[20]; /*學(xué)生姓名*/
char sex; /*性別*/
long num; /*學(xué)號(hào)*/
float score[3]; /*三科考試成績(jī)*/
};
struct stu stud[20]; /* 定義結(jié)構(gòu)體類(lèi)型數(shù)組stud ,*/
/ *該數(shù)組有2 0個(gè)結(jié)構(gòu)體類(lèi)型元素* /
其數(shù)組元素各成員的引用形式為:
stud[0].name 、stud[0].sex、stud[0].score[i];
stud[1].name、stud[1].sex、stud[1].score[i];
. . .
. . .
stud[19].name、stud[19].sex、stud[19].score[i];
[例7-1] 設(shè)某組有4 個(gè)人,填寫(xiě)如下的登記表,除姓名、學(xué)號(hào)外,還有三科成績(jī),編程實(shí)現(xiàn)對(duì)表格的計(jì)算,求解出每個(gè)人的三科平均成績(jī),求出四個(gè)學(xué)生的單科平均,并按平均成績(jī)由高分到低分輸出。
NumberNameEnglishMathemrPhysicsAverage
1Liping789876.
2Wanglin669086.
3Jiangbo897076.
4Yangming9010067.
題目要求的問(wèn)題多,采用模塊化編程方式,將問(wèn)題進(jìn)行分解如下:
1) 結(jié)構(gòu)體類(lèi)型數(shù)組的輸入。
2) 求解各學(xué)生的三科平均成績(jī)。
3) 按學(xué)生的平均成績(jī)排序。
4) 按表格要求輸出。
5) 求解組內(nèi)學(xué)生單科平均成績(jī)并輸出。
6) 定義m a i n ( )函數(shù),調(diào)用各子程序。
第一步,根據(jù)具體情況定義結(jié)構(gòu)體類(lèi)型。
struct stu
{
char name[20]; /*姓名* /
long number; /*學(xué)號(hào)* /
float score[4]; /* 數(shù)組依此存放English、Mathema、Physics,及Average*/
} ;
由于該結(jié)構(gòu)體類(lèi)型會(huì)提供給每個(gè)子程序使用,是共用的,所以將其定義為外部的結(jié)構(gòu)體類(lèi)型,放在程序的最前面。
第二步,定義結(jié)構(gòu)體類(lèi)型數(shù)組的輸入模塊。
void input(arr,n) /*輸入結(jié)構(gòu)體類(lèi)型數(shù)組arr 的n個(gè)元素*/
struct stu arr[];
int n;
{
int i,j;
char temp[30];
for (i=0;i
printf("\ninput name,number,English,mathema,physic\n"); /*打印提示信息* /
gets(arr[i].name); /* 輸入姓名*/
gets(temp); /* 輸入學(xué)號(hào)*/
arr[i].number = atol(temp);
for(j = 0; j < 3; j++)
{
gets(temp); /*輸入三科成績(jī)* /
arr[i].score[j] = atoi(temp);
}
}
}
第三步,求解各學(xué)生的三科平均成績(jī)。
在結(jié)構(gòu)體類(lèi)型數(shù)組中第i個(gè)元素arr[i]的成員score的前三個(gè)元素為已知,第四個(gè)Average需計(jì)算得到。
void aver(arr,n)
struct stu arr[];
int n;
{
int i,j;
for(i=0;i
arr[i].score[3] = 0;
for(j=0;j<3;j++)
arr[i].score[3]=arr[i].score[3]+arr[i].score[j]; /* 求和*/
arr[i].score[3]=arr[i].score[3] /3; /* 平均成績(jī)* /
}
}
第四步,按平均成績(jī)排序,排序算法采用冒泡法。
void order(arr,n)
struct stu arr[];
int n;
{
struct stu temp;
int i,j,x,y;
for(i = 0; i < n - 1; i++)
for( j = 0; j < n - 1 - i; j++)