NOIP 2003 普及组 复赛 table 乒乓球

时间:2022-06-30 20:42:36

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);
}