1038. 统计同成绩学生(20)
本题要求读入N名学生的成绩,将获得某一给定分数的学生人数输出。
输入格式:
输入在第1行给出不超过105的正整数N,即学生总人数。随后1行给出N名学生的百分制整数成绩,中间以空格分隔。最后1行给出要查询的分数个数K(不超过N的正整数),随后是K个分数,中间以空格分隔。
输出格式:
在一行中按查询顺序给出得分等于指定分数的学生人数,中间以空格分隔,但行末不得有多余空格。
输入样例:10 60 75 90 55 75 99 82 90 75 50 3 75 90 88输出样例:
3 2 0
分析:
有些题目··就是对有些语言不友好。这道题的思路其实就是用一个Int[101]数组代表不同分数,出现一个分数只要去查询这个数组就好了。但是!C#!处理输入太慢···自己写了处理输入的算法,还是超时···真是无语了
不过通过这道题目也知道了一个知识点,WINDOWS系统中,换行是用\r\n的,别的是用\n,所以要注意哦~这里用的版本是用来测试的(服务器应该是Linux),windows上测试的话,用vs要把\n替换成\r
using System; namespace PAT { class Program { static short[] Grade = new short[101]; static void Main() { int length = int.Parse(Console.ReadLine()); GetStudentGrades(); GetQueryGrades(); } static void GetStudentGrades() { string number = ""; char ch = (char)Console.Read(); while ( ch != '\n') { while(ch != ' ' && ch != '\n') { number += ch; ch = (char)Console.Read(); } Grade[int.Parse(number)]++; number = ""; if (ch == '\n' ) break; ch = (char)Console.Read(); } } static void GetQueryGrades() { string number = ""; char ch = (char)Console.Read(); while(ch != ' ') { number += ch; ch = (char)Console.Read(); } int quertTimes = int.Parse(number); string msg = ""; number = ""; ch = (char)Console.Read(); int i = 0; while (i < quertTimes) { while (ch != ' ' && ch != '\n') { number += ch; ch = (char)Console.Read(); } msg += Grade[int.Parse(number)] + " "; number = ""; if (ch == '\n') break; ch = (char)Console.Read(); i++; } Console.Write(msg.TrimEnd()); } } }