【2020模拟考试T3】【PAT乙】1028 人口普查 (20分) 字符串比较
problem
1028 人口普查 (20分)
某城镇进行人口普查,得到了全体居民的生日。现请你写个程序,找出镇上最年长和最年轻的人。
这里确保每个输入的日期都是合法的,但不一定是合理的——假设已知镇上没有超过 200 岁的老人,而今天是 2014 年 9 月 6 日,所以超过 200 岁的生日和未出生的生日都是不合理的,应该被过滤掉。
输入格式:
输入在第一行给出正整数 N,取值在(0,10
5
];随后 N 行,每行给出 1 个人的姓名(由不超过 5 个英文字母组成的字符串)、以及按 yyyy/mm/dd(即年/月/日)格式给出的生日。题目保证最年长和最年轻的人没有并列。
输出格式:
在一行中顺序输出有效生日的个数、最年长人和最年轻人的姓名,其间以空格分隔。
输入样例:
5
John 2001/05/12
Tom 1814/09/06
Ann 2121/01/30
James 1814/09/05
Steve 1967/11/20
输出样例:
3 Tom John
solution
这场考试写的我委屈啊,前三题一共半个小时就写完了,T3不知道为什么格式错了两个点,加起来就50分了。
结果后面两个半小时两道题一分没拿到,雾,可能是空调间有点冷然后头晕,加上昨晚没睡好犯困,加上qwq,算了我菜就是了。
主要是好久没写代码了,好多语法都不会,然后在那里试啊试的。本来T4写个结构就好了然而不会,T5归并和插入排序就写了一个小时多,手动调试语法一点都不好玩。
测试点4错的原因是答案为0的时候不输出人民
测试点5错因没找到,看了标程换了一个版本
错点是,用整体的字符串比较替代局部的数字比较,本来就没有必要去划分数字。
//AC
#include<iostream>
using namespace std;
int main(){
int n, sum=0; cin>>n;
string old,young,oldnum="2014/09/06", youngnum="1814/09/06";
while(n--){
string a, b;
cin>>a>>b;
if(b<"1814/09/06" || b>"2014/09/06")continue;
sum++;
if(b>=youngnum)young = a, youngnum=b;
if(b<=oldnum)old=a, oldnum = b;
}
if(sum!=0)cout<<sum<<" "<<old<<" "<<young<<"\n";
else cout<<sum<<"\n";
return 0;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
//WA,测试点4调不出来了
#include<iostream>
#include<string>
using namespace std;
int main(){
int n; cin>>n;
int sum = 0, oldd=-1,youngg=300; string old,young;
while(n--){
string a,b;
cin>>a>>b;
int y,m,d;
y = (b[0]-'0')*1000+(b[1]-'0')*100+(b[2]-'0')*10+(b[3]-'0');
m = (b[5]-'0')*10+(b[6]-'0');
d = (b[8]-'0')*10+(b[9]-'0');
if(y<1814 || y==1814&&m<9 || y==1814&&m==9&&d<6){continue;}
if(y>2014 || y==2014&&m>9 || y==2014&&m==9&&d>6){continue;}
sum++;
int year = 2014-y;
if(m<9 || m==9&&d<6)year -= 1;
//cout<<y<<" "<<m<<" "<<d<<" "<<year<<"\n";
if(year>oldd){old=a;oldd=year;}
if(year<youngg){young=a;youngg=year;}
}
if(sum!=0)cout<<sum<<' '<<old<<' '<<young<<'\n';//wa3
else cout<<sum<<"\n";
return 0;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
文章来源: gwj1314.blog.csdn.net,作者:小哈里,版权归原作者所有,如需转载,请联系作者。
原文链接:gwj1314.blog.csdn.net/article/details/107517863
- 点赞
- 收藏
- 关注作者
评论(0)