解题思路:
用一个二维数组a[i][j]保存三科成绩,用数组b保存每个学生的总分,数组c保存学号,数组d保存语文成绩。
先从键盘输入人数n以及成绩,再初始化几个数组:

  1. for(i=0;i<n;i++)
  2. {
  3. for(j=0;j<3;j++)
  4. {
  5. scanf("%d",&a[i][j]);
  6. b[k]+=a[i][j];
  7. c[k]=i+1;
  8. d[k]=a[i][0];
  9. }
  10. k++;
  11. }

接着进行排序处理,用选择排序方法,同时数组c跟着数组b一起排序,保证学号和成绩统一,如果总分相同,则判断语文成绩大小,如果语文成绩相同,则判断学号大小,小的放在前面。最后输出数组c和数组b,用空格隔开。

参考代码,大佬救命,运行错误50%,结果是正确的,不知道怎么解决:

  1. #include<stdio.h>
  2. int main()
  3. {
  4. int n,a[100][100];
  5. int b[100],temp=0;
  6. scanf("%d",&n);
  7. int i,j,k=0,t=0;
  8. int c[n],d[n];
  9. for(i=0;i<n;i++)
  10. {
  11. for(j=0;j<3;j++)
  12. {
  13. scanf("%d",&a[i][j]);
  14. b[k]+=a[i][j];
  15. c[k]=i+1;
  16. d[k]=a[i][0];
  17. }
  18. k++;
  19. }
  20. for(i=0;i<k;i++)
  21. {
  22. for(j=i;j<k;j++)
  23. {
  24. if(b[i]<b[j])
  25. {
  26. temp=b[i];
  27. b[i]=b[j];
  28. b[j]=temp;
  29. t=c[i];
  30. c[i]=c[j];
  31. c[j]=t;
  32. }
  33. else if(b[i]==b[j])
  34. {
  35. if(d[i]<d[j])
  36. {
  37. t=d[i];
  38. d[i]=d[j];
  39. d[j]=t;
  40. }
  41. else if(d[i]==d[j])
  42. {
  43. if(c[i]>c[j])
  44. {
  45. t=c[i];
  46. c[i]=c[j];
  47. c[j]=t;
  48. }
  49. }
  50. }
  51. }
  52. }
  53. for(i=0;i<5;i++)
  54. {
  55. printf("%d %d\n",c[i],b[i]);
  56. }
  57. return 0;
  58. }
点赞(0)
 

9 分

1 人评分

 

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 2 条评论

lantern 7月前 回复TA
说错了,是在语文成绩相同的情况下,没有对学号排序
lantern 7月前 回复TA
代码没注释懒得看,我看了一下数据,你的数组大小太小了,把数组大小改成300就行了,还有一个问题就是假如分数相同的情况下语文高的排前面,你的没有对语文高的排序