PAT乙级练习题1028 人口普查
题目:
某城镇进行人口普查,得到了全体居民的生日。现请你写个程序,找出镇上最年长和最年轻的人。
这里确保每个输入的日期都是合法的,但不一定是合理的——假设已知镇上没有超过 200 岁的老人,而今天是 2014 年 9 月 6 日,所以超过 200 岁的生日和未出生的生日都是不合理的,应该被过滤掉。
输入格式:
输入在第一行给出正整数 N,取值在(0,105];随后 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
思路历程:
这道题我刚开始的思路是将输入的生日字符串中的年,月,日都提取出来,转换成数字,再和当前日期相减来判断是否超过200岁。但是判断年龄时就开始混乱了,比如生日是1813/09/07,那他还没过生日应该是200岁还是201岁呢?生日是1814/09/05,那他没过生日还是199岁也符合条件啊。
然后看了解析,发现只要比较两个临界的生日日期就行了,就是1814/09/06和2014/09/06之间的生日才符合条件,而且可以直接比较字符串的大小,不用转换数字。
此外也可以将年龄转换为数字比较
踩坑:
- 如果没有符合的生日,则只输出0,无需其他输出
- 设置初始最大年龄的生日时,应设为临界值"z"(ASCII表最大值),这样才可做判断,判断成立别忘了更新最大年龄生日
代码:
#include <iostream>
using namespace std;int main(){int N;int count = 0;string name;string birthday;string oldest_name, oldest_birthday="z";string youngest_name, youngest_birthday="";cin >> N;for(int i = 0; i < N; ++i){cin >> name >> birthday;if(birthday>="1814/09/06" && birthday<="2014/09/06"){++count;if(birthday < oldest_birthday){oldest_name = name;oldest_birthday = birthday;}if(birthday > youngest_birthday){youngest_name = name;youngest_birthday = birthday;}}}if(count == 0){cout << 0;}else{cout << count << " " << oldest_name << " " << youngest_name;}return 0;
}
参考的解析:
1018.人口普查(没有判断符合生日数量为0的情况)
1028. 人口普查(20)(将年龄转换为数字比较)
PAT乙级练习题1028 人口普查相关推荐
- 【PAT乙级】1028 人口普查
目录 一.题目 二.我的AC代码 一.题目 1028 人口普查 (20分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合 ...
- 【PAT乙级】1028 人口普查 (20 分)
题目地址 #include<bits/stdc++.h> using namespace std; int ans; string small="99999999"; ...
- 【2020模拟考试T3】【PAT乙】1028 人口普查 (20分) 字符串比较
problem 1028 人口普查 (20分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇 ...
- PAT乙级C语言 1028 人口普查
思路 判断是否符合要求并计数,把符合的结构输入另一个数组,对该数组进行qsort排序,然后输出第一个和最后一个元素里的相关成员 推荐 我觉得这个写的很好(呜呜呜我写了七十几行人家写二十几行就好了,差距 ...
- PAT乙级1028 人口普查 (20 分)
1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...
- 【PAT】1028 人口普查
一.题目描述 PAT 1028 人口普查 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有 ...
- C++学习之路 | PTA乙级—— 1028 人口普查 (20 分)(精简)
1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...
- PAT 1028 人口普查
1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...
- PAT 乙 1028 人口普查
1028. 人口普查(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 某城镇进行人口普查,得到了全体居民的 ...
- 1028 人口普查 (20 分)C++ 示例代码
1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...
最新文章
- matlab创建图形用户界面,Matlab 用户图形界面 基础 (一)
- 数字对 (长乐一中模拟赛day2T2)
- 手把手教你搭建一个基于Java的分布式爬虫系统
- (转)!注意:PreTranslateMessage弹出框出错
- mysql path conflict_yum安装MySQL出现conflict problem
- 两千块钱带来的 quot;希望quot;
- ubuntu简单的小命令
- setuptools find_packages
- setlength java_Java StringBuilder setLength()方法与示例
- 第七章:Servlet
- C#经典面试题及答案 (3)
- java 计划任务_Java实现定时任务的几种方案
- Parse分析之 -- Enum.Parse
- 播放.avi后缀视频报出0xc00d5212,编码格式不支持
- paypal支付开发接口(转)
- 《深入理解Java虚拟机》笔记04之垃圾收集算法
- 队列 front rear
- 移动硬盘未知usb设备(设定地址失败)
- JQueryUI自动补全 搜索提示实践
- networkx教程