程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 結構體數組的定義和引用(三)

結構體數組的定義和引用(三)

編輯:關於C語言

第七步,定義m a i n ( )函數,列出完整的程序清單。
#include
#include
struct stu
{
char name[20];
long number;
float score[4];
} ;
m a i n ( )
{
void input(); / *函數聲明* /
void aver();
void order();
void output();
void out_row();
struct stu stud[4]; / * 定義結構體數組* /
float row[3];
i n p u t ( s t u d , 4 ) ; / *依此調用自定義函數* /
a v e r ( s t u d , 4 ) ;
o r d e r ( s t u d , 4 ) ;
o u t p u t ( s t u d , 4 ) ;
o u t _ r o w ( s t u d , 4 ) ;
}
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
void input(arr,n)
struct stu arr[];
int n;
{ int i,j;
char temp[30];
for (i=0;i<N;I++)
{
printf("\nInput Name,Number,English,Mathema,Physic\n");
g e t s ( a r r [ i ] . n a m e ) ;
g e t s ( t e m p ) ;
a r r [ i ] . n u m b e r = a t o l ( t e m p ) ;
f o r ( j = 0 ; j < 4 ; j + + )
p r i n t f ( " % 7 . 2 f | " , a r r [ i ] . s c o r e [ j ] ) ;
p r i n t f ( " \ n " ) ;
p r i n t f ( " - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ n " ) ;
}
}
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
void out_row(arr,n)
int n;
struct stu arr[];
{
float row[4]={0,0,0,0};
int i,j;
f o r ( i = 0 ; i < 4 ; i + + )
{
f o r ( j = 0 ; j < n ; j + + )
r o w [ i ] = r o w [ i ] + a r r [ j ] . s c o r e [ i ] ;
r o w [ i ] = r o w [ i ] / n ;
}
printf("|%19c|",' ');
for (i=0;i<4;i++)
p r i n t f ( " % 7 . 2 f | " , r o w [ i ] ) ;
p r i n t f ( " \ n - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ n " ) ;
}

程序中要謹慎處理以數組名作函數的參數。由於數組名作為數組的首地址,在形參和實參結合時,傳遞給子程序的就是數組的首地址。形參數組的大小最好不定義,以表示與調用函數的數組保持一致。在定義的結構體內,成員score[3]用於表示計算的平均成績,也是我們
用於排序的依據。我們無法用數組元素進行相互比較,而只能用數組元素的成員score[3]進行比較。在需要交換的時候,用數組元素的整體包括姓名、學號、三科成績及平均成績進行交換。在程序order()函數中,比較采用:arr[j].score[3]>arr[j+1].score[3],而交換則采用:
arr[j]arr[j+1]

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved