日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

学生数据排序

發布時間:2023/11/27 生活经验 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 学生数据排序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

學生數據排序


Description

某班 有n個學生(不超過100),每個學生的信息包括學號(long no),姓名(char name[9])和三門課的成績(int score[4],其中score[0]~score[3]分別用來存放總分,語文,數學和英語的成績)。

編寫程序,錄入n個學生的信息,然后按照總分降序排序(如果總分相同的按照學號小的在前),最后輸出排序后的學生信息。

注意:main函數已經給定(如下所示)。

? ? ? ? ? ?請將程序補充完整。

? ? ? ? ? ?提交時只需要提交自己補充的代碼部分,不需要提交給定的main函數的代碼部分。

#include<stdio.h>int main()
{int n;struct student stu[100];while(scanf("%d",&n)!=EOF){input(stu,n);   //讀入n個學生的數據sort(stu,n);   //按照總分降序排序,如果總分相同的學號小的在前面print(stu,n);   //輸出n個學生的信息}return 0;
}

Input

?包含多組測試數據,每組測試數據第一行包含1個整數n(大于1小于等與100),表示學生人數。接下來的n行為n個學生的詳細信息,包括學號,姓名,語文,數學和英語的分數,個數據之間用空格隔開。

Output

?每組測試數據輸出占n行,每行輸出一個學生的信息。每一行的輸出數據依次為:排名,學號,姓名,總分,英文成績,數學成績和英語成績。各部分數據之間用空格隔開。(具體詳見樣例輸出)

Sample Input

5
1001 aaa 54 85 65
1002 bbb 54 65 85
1003 ccc 88 99 99
1004 ddd 35 50 50
1005 eee 99 99 99

?

Sample Output

1 1005 eee 297 99 99 99
2 1003 ccc 286 88 99 99
3 1001 aaa 204 54 85 65
4 1002 bbb 204 54 65 85
5 1004 ddd 135 35 50 50

題目分析:

仔細讀題,能讀懂這題的意思,一個結構體的好例題。

C語言中結構體的用法:

參考https://blog.csdn.net/eric_e/article/details/79340947

涉及到結構體的互換,需要另外定義一個結構體來交換。(詳見代碼中的 “ t ” )

我用的冒泡排序(因為不想手打快排,說白了就是懶。。)

打代碼的時候一定要仔細……結構體看得眼花……

以下提供完整代碼,抄作業是不對的喲~


#include<stdio.h>
struct student
{char name[9];long no;int score[4];
};
void input(struct student stu[100],int n)
{int i;for(i=1;i<=n;i++){scanf("%ld %s %d %d %d",&stu[i].no,&stu[i].name,&stu[i].score[1],&stu[i].score[2],&stu[i].score[3]);stu[i].score[0]=stu[i].score[1]+stu[i].score[2]+stu[i].score[3];}return;
}
void sort(struct student stu[100],int n)
{struct student t;int i,j;for(i=1;i<=n;i++)for(j=i+1;j<=n;j++){if(stu[i].score[0]<stu[j].score[0] || stu[i].score[0]==stu[j].score[0] && stu[i].no>stu[j].no){t=stu[i];stu[i]=stu[j];stu[j]=t;}}return;
}
void print(struct student stu[100],int n)
{int i;for(i=1;i<=n;i++){printf("%d ",i);printf("%ld %s %d %d %d %d\n",stu[i].no,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3]);}return;
}
int main()
{int n;struct student stu[100];while(scanf("%d",&n)!=EOF){input(stu,n);   //讀入n個學生的數據sort(stu,n);   //按照總分降序排序,如果總分相同的學號小的在前面print(stu,n);   //輸出n個學生的信息}return 0;
}

?

總結

以上是生活随笔為你收集整理的学生数据排序的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。