NOIP 2003 普及组 复赛 table 乒乓球
2017-03-21 11:24
288 查看
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);
}
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);
}
相关文章推荐
- Cpp环境【Code[VS]1084】【NOIP2003普及组】乒乓球
- 【C++心路历程21】NOIP2003普及组复赛第4题数字游戏
- [NOIP2003普及组]乒乓球
- [普及]NOIP 2003 乒乓球
- NOIP 2003 - 普及组 乒乓球 模拟+“高级”水题 重庆一中高2018级竞赛班第八次测试 2016.8.7 Problem 4
- NOIP2005-普及组复赛-第三题-采药
- NOIP 2003 普及组 数字游戏
- NOIP 2010 普及组 复赛 sanguo 三国游戏
- NOIP2006普及组复赛试题 1.明明的随机数(桶排序,冒泡排序,快速排序)
- NOIP2010-普及组复赛-第一题-数字统计
- 【用膝盖写代码系列】(2):NOIP2011普及组复赛题目详解
- NOIP2012普及组复赛解题报告
- 05:统计单词数【NOIP2011复赛普及组第二题】
- 校门外的树(NOIP2005复赛 普及组 第二题)
- NOIP 2013 普及组 复赛 count 计数问题
- NOIP 2005 普及组 复赛 tree 校门外的树
- NOIP 2004 普及组 复赛 peanuts 花生采摘
- NOIP2015-普及组复赛-第一题-金币
- NOIP2001-普及组复赛-第二题-最大公约数和最小公倍数问题
- [NOIP2003] 普及组