参考代码:
import java.util.Scanner; public static void main(String[] args){ Scanner sc=new Scanner(System.in); int num=sc.nextInt(); int [][] n=new int [num][5];//定义了个二维数组 for(int i=0;i<num;i++){ for(int j=0;j<3;j++){ //前三项(n[i][0]、n[i][1]、n[i][2])用来储存语文、数学和英语成绩 n[i][j]=sc.nextInt(); } n[i][3]=i+1; //第四项(n[i][3])储存学号 n[i][4]=n[i][0]+n[i][1]+n[i][2]; //第五项(n[i][4])储存总分 } for(int i=0;i<num-1;i++){ for(int j=i+1;j<num;j++){ if(n[i][4]<n[j][4]){ //总分判断 exchange(n,i,j); } else if(n[i][4]==n[j][4]){ if(n[i][0]<n[j][0]){ //总分相同,语文分判断 exchange(n,i,j); } else if(n[i][0]==n[j][0]){ if(n[i][3]>n[j][3]){ //总分、语文分相同,学号判断 exchange(n,i,j); } } } } } for(int i=0;i<5;i++){ System.out.println(n[i][3]+" "+n[i][4]); } } public static void exchange(int [][]n,int x,int y){ //这个方法是用来交换学生的信息(学号和成绩) int t; for(int i=0;i<5;i++){ t=n[x][i]; n[x][i]=n[y][i]; n[y][i]=t; } }
0.0分
2 人评分
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:638 |
K-进制数 (C语言描述,蓝桥杯)浏览:955 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:561 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:676 |
Tom数 (C语言代码)浏览:581 |
IP判断 (C语言代码)浏览:592 |
格式化数据输出 (C语言代码)浏览:882 |
马拦过河卒 (C语言代码)浏览:1213 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:1302 |
非常简单的算法,题解1049:C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:639 |