CCF习题 成绩大排队(JAVA)

【问题描述】

读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。

【输入形式】

每个测试输入包含1个测试用例,格式为

 第1行:正整数n
  第2行:第1个学生的姓名 学号 成绩
  第3行:第2个学生的姓名 学号 成绩
  ... ... ...
  第n+1行:第n个学生的姓名 学号 成绩

其中姓名和学号均为不超过10个字符的字符串,成绩为0到100之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。

【输出形式】

对每个测试用例输出2行,第1行是成绩最高学生的姓名和学号,第2行是成绩最低学生的姓名和学号,字符串间有1空格。

【样例输入】

3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95

【样例输出】

Mike CS991301
Joe Math990112
import java.util.Scanner;

public class Main {
	@SuppressWarnings("resource")
	public static void main(String[] args)
	{
		Student greatSt=new Student(),badSt=new Student(),st=new Student();
		int Max=0,Min=100;
		Scanner sc=new Scanner(System.in);
		int num=sc.nextInt();
		for(int i=0;i<num;i++)
		{
			st.setName(sc.next());
			st.setStNo(sc.next());
			st.setGrade(sc.nextInt());
			if(st.getGrade()>Max)
			{
				greatSt.setName(st.getName());
				greatSt.setStNo(st.getStNo());
				greatSt.setGrade(st.getGrade());
				Max=st.getGrade();
			}
			if(st.getGrade()<Min)
			{
				badSt.setName(st.getName());
				badSt.setStNo(st.getStNo());
				badSt.setGrade(st.getGrade());
				Min=st.getGrade();
			}
		}
		System.out.println(greatSt.getName()+" "+greatSt.getStNo());
		System.out.println(badSt.getName()+" "+badSt.getStNo());
		
	}
}
class Student {
	String name;
	String stNo;
	int grade;
	
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getStNo() {
		return stNo;
	}
	public void setStNo(String stNo) {
		this.stNo = stNo;
	}
	public int getGrade() {
		return grade;
	}
	public void setGrade(int grade) {
		this.grade = grade;
	}
	
	
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值