結構體綜合訓練
有10個學生,每個學生的資料包括學號、姓名、3門課的成績,編寫如下函式:
① 輸入10個學生的基本資訊(Input);
② 求出每個學生的平均分(Average);
③ 求出最高分的學生資訊(High_Score);
④ 輸出每個學生的資訊(Output);
⑤ 按平均分從高到低的順序排序(Sort)。
參考程式碼如下:
#include <stdio.h>
#include <math.h>
struct Student{
int num;
char name[10];
int score[3];
float average;
};
int input(struct Student person[], int n)
{
int i,j,k;
for(i=0;i<n;i++)
{
scanf("%d",&person[i].num);
getchar();
gets(person[i].name);
for(j=0;j<3;j++)
scanf("%d",&person[i].score[j]);
}
return 0;
}
int output(struct Student person[], int n)
{
int i,j,k;
printf("=======================\n");
for(i=0;i<3;i++)
{
printf("%5d",person[i].num);
printf("%10s",person[i].name);
for(j=0;j<3;j++)
printf("%5d",person[i].score[j]);
putchar('\n');
}
return 0;
}
int average(struct Student person[], int n)
{
int i,j,k=0;
float average,maxaverage=0.;
for(i=0;i<3;i++)
{
average=0.0;
for(j=0;j<3;j++)
average+=person[i].score[j];
person[i].average=average/3;
printf("%6.2f",person[i].average);
if(average/3>maxaverage)
{
maxaverage=average/3;
k=i;
}
}
putchar('\n');
printf("the best student is %s.\n",person[k].name);
return 0;
}
int sort(struct Student *ps[], int n)
{
int i,j,k;
struct Student *temp;
for(i=0;i<n;i++)
{
k=i;
for(j=i+1;j<n;j++)
{
if(ps[j]->average>ps[k]->average)
k=j;
}
if(k!=i)
{
temp=ps[i];
ps[i]=ps[k];
ps[k]=temp;
}
}
for(i=0;i<n;i++)
{
printf("%5d %10s %6.2f\n",ps[i]->num,ps[i]->name, ps[i]->average);
}
return 0;
}
int main()
{
struct Student stu[10]; //&stu[0], &stu[1], &stu[2] stu, stu+1, stu+2
struct Student *ps[10]; //ps[0], ps[1], ps[2]
int i,j,k;
input(stu,10);
output(stu,10);
average(stu,10);
for(i=0;i<10;i++)
ps[i]=stu+i;
sort(ps,10);
return 0;
}
#include <stdio.h>
#define M 3
typedef struct stu{
int num;
char name[10];
int score[3];
float average;
}Student;
int input(Student person[],int n);
int output(Student person[],int n);
int best(Student person[],int n);
int sort(Student person[],int n);
int main()
{
int in;
Student person[M];
while(1)
{
printf("\t1. input\n");
printf("\t2. display\n");
printf("\t3. find the best\n");
printf("\t4. sort\n");
printf("\t5. quit\n");
printf("\t please select:");
scanf("%d",&in);
switch(in)
{
case 1: input(person,3); break;
case 2: output(person,3); break;
case 3: best(person,3); break;
case 4: sort(person, 3); break;
case 5: return 0;
}
}
return 0;
}
int input(Student person[],int n)
{
int i,j;
float average;
for(i=0;i<n;i++)
{
scanf("%d",&person[i].num);
getchar();
gets(person[i].name);
average=0.;
for(j=0;j<3;j++){
scanf("%d",&person[i].score[j]);
average+=person[i].score[j];
}
person[i].average=average/3;
}
return 0;
}
int output(Student person[],int n)
{
int i,j;
printf("number\t name\t Chinese\t Math \t English\t average\n");
for(i=0;i<n;i++)
{
printf("%8d",person[i].num);
printf("%8s",person[i].name);
for(j=0;j<3;j++){
printf("%8d",person[i].score[j]);
}
printf("%8.2f\n",person[i].average);
}
return 0;
}
int best(Student person[],int n)
{
int i,j;
j=0;
for(i=1;i<n;i++)
{
if(person[i].average>person[j].average)
j=i;
}
printf("the best student is:\n");
i=j;
printf("%8d",person[i].num);
printf("%8s",person[i].name);
for(j=0;j<3;j++){
printf("%8d",person[i].score[j]);
}
printf("%8.2f\n",person[i].average);
return 0;
}
int sort(Student person[],int n)
{
Student *ps[M],*temp;
int i,j;
for(i=0;i<n;i++)
ps[i]=person+i;
for(i=0;i<n;i++)
{
for(j=i+1;j<n;j++)
{
if((*(ps+i))->average<(*(*(ps+j))).average)
//if (ps[i]->average<ps[j]->average)
{
temp=ps[i];
ps[i]=*(ps+j);
ps[j]=temp;
}
}
}
for(i=0;i<n;i++)
{
printf("%5d%10s%5d%5d%5d%8.2f\n",ps[i]->num, ps[i]->name,ps[i]->score[0],ps[i]->score[1],ps[i]->score[2],ps[i]->average);
}
return 0;
}
相關文章
- 物件導向綜合訓練物件
- Java基礎 --- 物件導向綜合訓練Java物件
- Siamese RPN 訓練網路結構解析
- 生成對抗網路綜述:從架構到訓練技巧架構
- ADMIN07 - 綜合練習
- Java基礎 --- 綜合練習Java
- SparkSql與Redis綜合練習SparkSQLRedis
- 綜合實訓週報八
- 模組化單體架構綜合指南架構
- 迴圈高階綜合練習
- 1.23訓練總結
- 綜合練習——洗牌發牌Easy版
- Day5-SQL綜合練習(Datawhale)SQL
- 結構體,列舉,聯合結構體
- c++結構體、共用體(聯合體)C++結構體
- 資料結構實驗三:線性表綜合實驗資料結構
- 程式設計實踐(Pandas)綜合練習1程式設計
- CoLAKE: 如何實現非結構性語言和結構性知識表徵的同步訓練
- 計算機網路實驗三 綜合性訓練(搭建中小企業園區網)計算機網路
- 做題小結 DP訓練
- 什麼是LLM大模型訓練,詳解Transformer結構模型大模型ORM
- .NET 雲原生架構師訓練營(組合模式)--學習筆記架構模式筆記
- 適合AI訓練的遊戲框架AI遊戲框架
- JVM篇1:[-結構綜述-]JVM
- 系統架構師綜合知識架構
- 2024.09.19短時訓練賽總結
- 做題小結 dp訓練6
- 異構模擬:打造更可靠的綜合化航空電子軟體
- 長沙前端培訓機構:10個適合新手練手的前端專案前端
- 綜合設計——多源異構資料採集與融合應用綜合實踐
- LeetCode演算法訓練-回溯總結LeetCode演算法
- 新高一暑假第一期集訓恢復性訓練【資料結構-雜題小練】(並查集)(補)資料結構並查集
- SSD演算法程式碼介訓練演算法整體架構演算法架構
- pytorch入門2.2構建迴歸模型初體驗(開始訓練)PyTorch模型
- [原始碼解析] 模型並行分散式訓練Megatron (2) --- 整體架構原始碼模型並行分散式架構
- 關於培訓結構
- 二維陣列和函式綜合程式設計練習陣列函式程式設計
- 『政善治』Postman工具 — 13、Postman介面測試綜合練習Postman
- 2024.04.18每日收穫之聯合體結構體記憶體分配結構體記憶體