NOIP 2003 普及组 复赛 table 乒乓球
1.字符串读取,字符统计。
2.先按正常的21球,11球,建立两套统计系统,进行处理。
3.不考虑特殊情况,先将样例通过,在进行特殊情况修改。
4.陷阱,11:0或0:11均可,即有可能赢也有可能输,这是容易忽略的地方。
5.编着编着才发现11球的含义,11:9也算一局,一直以为是总计11球,弄明白了,是有一人达到11球。
6.该题同样要注意的细节比较多。
附上AC代码,编译环境Dev-C++4.9.9.2
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct node{
int w;
int l;
}old_t[10000],new_t[10000];//old 21分 new 11分 数组100开太小
int main(){
char s_t[30];
int len;
int i;
int old_w=0,old_l=0,new_w=0,new_l=0;//初始化别忘了,一开始忘了new_w,new_l初始化,结果不对
int flag=0;
int old_count=0,new_count=0;
int max;
while(scanf("%s",s_t)){
len=strlen(s_t);
for(i=0;i<len;i++){
if(s_t[i]=='W'){
old_w++;
new_w++;
}
else if(s_t[i]=='L'){
old_l++;
new_l++;
}
else if(s_t[i]=='E'){
flag=1;
break;
}
max=old_w>old_l?old_w:old_l;
if(max>=21&&abs(old_w-old_l)>=2){//忘了绝对值,查了好一会
old_t[old_count].w=old_w;
old_t[old_count].l=old_l;
old_count++;
old_w=0;
old_l=0;
}
max=new_w>new_l?new_w:new_l;
if(max>=11&&abs(new_w-new_l)>=2){//忘了绝对值,查了好一会
new_t[new_count].w=new_w;
new_t[new_count].l=new_l;
new_count++;
new_w=0;
new_l=0;
}
}
if(flag){
old_t[old_count].w=old_w;
old_t[old_count].l=old_l;
old_count++;
new_t[new_count].w=new_w;
new_t[new_count].l=new_l;
new_count++;
break;
}
}
for(i=0;i<new_count;i++)
printf("%d:%d\n",new_t[i].w,new_t[i].l);
printf("\n");
for(i=0;i<old_count;i++)
printf("%d:%d\n",old_t[i].w,old_t[i].l);
}