1004 成绩排名(通过)

这篇文章算是借鉴的比较少的了哈哈哈。以前刷PTA的时候都是没有通过,大多是提交的别人的代码。看到自己的进步是非常开心的。

  • 首先看题

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

输入格式:

每个测试输入包含 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
  • 解题过程:

 学过C++,看到题目我就想用类数组进行解答。这是典型的学生管理类。

AC的代码:

#include<iostream>
#include<string>
#include<stdio.h>
using namespace std;

class mark
{
    string name,number;
    int score;
public:
    void Input(){cin>>name>>number>>score;}
    int get_s(){return score;}
    void Print(){cout<<name<<" "<<number<<endl;}
};
mark student[1000];
int main()
{
    int n,maxS,minS,maxI,minI;
    scanf("%d",&n);
    int a[n-1];
    //输入信息
    for(int i=0;i<n;i++)
    {
        student[i].Input();
        a[i]=student[i].get_s();
    }
    maxI=minI=0;
    maxS=minS=a[0];
    for(int i=0;i<n;i++)
    {
        if(maxS<a[i])
        {
            maxS=a[i];
            maxI=i;
        }
        if(minS>a[i])
        {
            minS=a[i];
            minI=i;
        }
    }
    student[maxI].Print();
    student[minI].Print();
    return 0;
}

想了这道题很久,开始是纠结到底在哪儿输入,是在类输入还是主函数输入。统统都试了。后面才知道可以定义一个输入的成员函数。每当主函数中需要输入时就调用改成员函数。第二,就是对象数组的长度了。本来是

int n;
scanf("%d",&n);
mark student[n-1];//定义对象数组

编译时候没有报错,但是运行就是的不到预期的结果。调试了一下发现还真是mark student[n-1];这地方有问题,到现在我也不明白为啥错了~_~!

然后就直接给一个确定的数,确定的大数组。mark student[100];提交结果是部分正确,有段错误。百度了一下段错误的原因有数组越界,但是应该不至于啊,100应该够大了。还有就是说大数组最好不要放在main()函数中,最好放在全局。好了,又提交一次,还是有错,但是错变少了。又想了一会儿,要不将数组长度改大点,于是数组长度就改成了1000。抱着侥幸的心理,竟然全部通过!AC了!耶✌!

上一篇:问题 1004: [递归]母牛的故事


下一篇:1004.最大连续1的个数III