题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1268
Description
在双鱼的乒乓球上一般都会标有三星,二星,或者一星的字样,星级越高就表示球的质量越好。
星级的评定和球的重量,直径,硬度等很多因素有关,不过在这里,我们只考虑球的重量对星级评定产生的影响。
乒乓球有一个标准的重量S,如果球的重量和标准越接近,星级就会越高。具体来讲,对于球的重量和S的差的绝对值,如果小于或等于D1,那么这个球就会被标为三星,如果大于D1且小于或等于D2,那么就会被标为二星,如果大于D2且小于或等于D3就会被标为一星,如果大于D3则不对其标星(D1
< D2 < D3)。
现在给你N个乒乓球,你需要计算其中各个星级的乒乓球各有多少个。
Input
输入的第一行包含一个整数T (1 <= T <= 20),表示接下来一共有T组测试数据。
对于每组数据,第一行包含5个整数N
(1 <= N <= 10), S (1 <= S <= 20), D1, D2, D3 (1 <= D1 < D2 < D3 <= 20),含义同上。接下来一行包含N个不大于20的正整数,依次描述了各个乒乓球的重量。
Output
对于每组数据,用一行输出三个整数,中间用空格隔开,分别表示N个球中三星,二星和一星的球各有多少个。
Sample Input
2 5 10 1 2 3 6 7 9 9 10 6 10 1 2 3 11 12 12 13 14 8
Sample Output
3 0 1 1 3 1
HINT
Source
代码如下:
#include <cstdio> #include <cmath> #include <cstring> #include <algorithm> using namespace std; #include <iostream> #include <string> string ss; int main() { int n; int f[27]; char s[10]; while(~scanf("%d",&n)) { memset(f,0,sizeof(f)); memset(s,0,sizeof(s)); char a, b; for(int i = 0; i < n; i++) { cin>>ss; if(ss == "print") { cin>>a; printf("%d\n",f[a-'a']); } else if(ss == "mov") { cin>>a>>b>>s; if(s[0]>='0' && s[0] <= '9') { int num = 0; int len = strlen(s); for(int j = 0; j < len; j++) { num = num*10+s[j]-'0'; } f[a-'a'] = num; } else f[a-'a'] = f[s[0]-'a']; } else if(ss == "add") { cin>>a>>b>>s; if(s[0]>='0' && s[0] <= '9') { int num = 0; int len = strlen(s); for(int j = 0; j < len; j++) { num = num*10+s[j]-'0'; } f[a-'a'] += num; } else f[a-'a'] += f[s[0]-'a']; } else if(ss == "sub") { cin>>a>>b>>s; if(s[0]>='0' && s[0] <= '9') { int num = 0; int len = strlen(s); for(int j = 0; j < len; j++) { num = num*10+s[j]-'0'; } f[a-'a'] -= num; } else f[a-'a'] -= f[s[0]-'a']; } } } return 0; }
时间: 2024-12-29 12:04:58