zoukankan      html  css  js  c++  java
  • 1004. 成绩排名 (20)

    读入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
    仔细想下,这道题的思路很简单,比大小,输出最大最小值,采用比较的方法,把第一个设置为最大,最小值,然后循环依次比较
    int i,n;
    	int max_score=0,min_score=0;
    	int max_i=1, min_i=1;
    	struct student
    	{	
    		char name[11];
    		char num[11];
    		int score;
    	};
    	cin >> n;
    	student *stu=new student[n];
    
    	for (i = 1; i <= n; i++)
    	{
    		cin >> stu[i].name >> stu[i].num >> stu[i].score;
    	}
    	max_score = stu[1].score;
    	min_score = stu[1].score;
    	for (i = 2; i <= n; i++)
    	{
    		if (stu[i].score > max_score)
    		{
    			max_i = i;
    			max_score = stu[i].score;
    		}
    		if (stu[i].score < min_score)
    		{
    			min_i = i;
    			min_score = stu[i].score;
    		}
    	}
    	cout << stu[max_i].name << " " << stu[max_i].num << endl;
    	cout << stu[min_i].name << " " << stu[min_i].num << endl;
    

      



  • 相关阅读:
    iframe,modaldialog父子窗口相互通信的问题
    bootstrap基础知识
    基于原生js的图片延迟加载
    通过原生js的ajax或jquery的ajax获取服务器的时间
    转 fiddler教程
    正则表达式
    es6 对象
    ES6
    axios
    javascript闭包和闭包的几种写法和用法
  • 原文地址:https://www.cnblogs.com/ZyCoder/p/6053210.html
Copyright © 2011-2022 走看看