鱼C论坛

 找回密码
 立即注册
查看: 551|回复: 2

[已解决]C语言题目

[复制链接]
发表于 2020-5-5 17:28:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
请问这道题目怎么用C语言写,我上传了图片,感谢大噶 作业(奖学金).png 作业(奖学金1).png
最佳答案
2020-5-5 20:10:28
  1. #if 0
  2.         By Cool_Breeze
  3.         Dev-C++ 5.11
  4.         x.c
  5. #endif

  6. #include <stdio.h>
  7. #include <string.h>

  8. void sawp(float* p1, float* p2,short len);
  9. int main(void)
  10. {
  11.         static float Achievement[300][5];
  12.         //0学号,1语文,2数学,3英语,4三科总和;
  13.         short n=0;
  14.         scanf("%d",&n);
  15.         getchar();
  16.         register short i=0;
  17.         for (i=0;i<n;i++)
  18.         {
  19.                 Achievement[i][0]=i+1;
  20.                 scanf("%f %f %f",&Achievement[i][1],&Achievement[i][2],&Achievement[i][3]);
  21.                 getchar();
  22.                 Achievement[i][4]=Achievement[i][1]+Achievement[i][2]+Achievement[i][3];
  23.         }
  24.         //sort
  25.         register short j=0;       
  26.         for (i=0;i<n-1;i++)
  27.                 for (j=i+1;j<n;j++)
  28.                 {
  29.                         if (Achievement[j][4] > Achievement[i][4])
  30.                         {
  31.                                 sawp(&Achievement[i][0],&Achievement[j][0],5);
  32.                                 continue;
  33.                         }
  34.                         else if (Achievement[j][4] == Achievement[i][4])//总成绩相等
  35.                         {
  36.                                 if  (Achievement[j][1] == Achievement[i][1])//语文相等
  37.                                 {
  38.                                         if (Achievement[j][0] > Achievement[i][0])// 比较学号
  39.                                         sawp(&Achievement[i][0],&Achievement[j][0],5);
  40.                                         continue;
  41.                                 }
  42.                                 else if (Achievement[j][1] > Achievement[i][1])
  43.                                 {
  44.                                         sawp(&Achievement[i][0],&Achievement[j][0],5);
  45.                                         continue;
  46.                                 }
  47.                         }
  48.                 }
  49.                        
  50.                                
  51.         for (i=0;i<5;i++)//前5名
  52.                 printf("%f %f\n",Achievement[i][0],Achievement[i][4]);
  53.         return 0;
  54. }
  55. void sawp(float* p1, float* p2,short len)
  56. {
  57.         register float t=0;
  58.         for (;len>0;p1++,p2++,len--)
  59.                 t=*p1,*p1=*p2,*p2=t;
  60. }

复制代码
  1. 6
  2. 90 67 80
  3. 87 66 91
  4. 78 89 91
  5. 88 99 77
  6. 67 89 64
  7. 78 89 98
  8. 6.000000 265.000000
  9. 4.000000 264.000000
  10. 3.000000 258.000000
  11. 2.000000 244.000000
  12. 1.000000 237.000000

  13. --------------------------------
  14. Process exited after 11.32 seconds with return value 0
  15. 请按任意键继续. . .
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-5 20:10:28 | 显示全部楼层    本楼为最佳答案   
  1. #if 0
  2.         By Cool_Breeze
  3.         Dev-C++ 5.11
  4.         x.c
  5. #endif

  6. #include <stdio.h>
  7. #include <string.h>

  8. void sawp(float* p1, float* p2,short len);
  9. int main(void)
  10. {
  11.         static float Achievement[300][5];
  12.         //0学号,1语文,2数学,3英语,4三科总和;
  13.         short n=0;
  14.         scanf("%d",&n);
  15.         getchar();
  16.         register short i=0;
  17.         for (i=0;i<n;i++)
  18.         {
  19.                 Achievement[i][0]=i+1;
  20.                 scanf("%f %f %f",&Achievement[i][1],&Achievement[i][2],&Achievement[i][3]);
  21.                 getchar();
  22.                 Achievement[i][4]=Achievement[i][1]+Achievement[i][2]+Achievement[i][3];
  23.         }
  24.         //sort
  25.         register short j=0;       
  26.         for (i=0;i<n-1;i++)
  27.                 for (j=i+1;j<n;j++)
  28.                 {
  29.                         if (Achievement[j][4] > Achievement[i][4])
  30.                         {
  31.                                 sawp(&Achievement[i][0],&Achievement[j][0],5);
  32.                                 continue;
  33.                         }
  34.                         else if (Achievement[j][4] == Achievement[i][4])//总成绩相等
  35.                         {
  36.                                 if  (Achievement[j][1] == Achievement[i][1])//语文相等
  37.                                 {
  38.                                         if (Achievement[j][0] > Achievement[i][0])// 比较学号
  39.                                         sawp(&Achievement[i][0],&Achievement[j][0],5);
  40.                                         continue;
  41.                                 }
  42.                                 else if (Achievement[j][1] > Achievement[i][1])
  43.                                 {
  44.                                         sawp(&Achievement[i][0],&Achievement[j][0],5);
  45.                                         continue;
  46.                                 }
  47.                         }
  48.                 }
  49.                        
  50.                                
  51.         for (i=0;i<5;i++)//前5名
  52.                 printf("%f %f\n",Achievement[i][0],Achievement[i][4]);
  53.         return 0;
  54. }
  55. void sawp(float* p1, float* p2,short len)
  56. {
  57.         register float t=0;
  58.         for (;len>0;p1++,p2++,len--)
  59.                 t=*p1,*p1=*p2,*p2=t;
  60. }

复制代码
  1. 6
  2. 90 67 80
  3. 87 66 91
  4. 78 89 91
  5. 88 99 77
  6. 67 89 64
  7. 78 89 98
  8. 6.000000 265.000000
  9. 4.000000 264.000000
  10. 3.000000 258.000000
  11. 2.000000 244.000000
  12. 1.000000 237.000000

  13. --------------------------------
  14. Process exited after 11.32 seconds with return value 0
  15. 请按任意键继续. . .
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-5 21:20:08 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 00:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表