C語言程序設(shè)計(第7章結(jié)構(gòu)體與共用體)2

字號:

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