题目:

某城镇进行人口普查,得到了全体居民的生日。现请你写个程序,找出镇上最年长和最年轻的人。

这里确保每个输入的日期都是合法的,但不一定是合理的——假设已知镇上没有超过 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 人口普查相关推荐

  1. 【PAT乙级】1028 人口普查

    目录 一.题目 二.我的AC代码 一.题目 1028 人口普查 (20分)   某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人.   这里确保每个输入的日期都是合 ...

  2. 【PAT乙级】1028 人口普查 (20 分)

    题目地址 #include<bits/stdc++.h> using namespace std; int ans; string small="99999999"; ...

  3. 【2020模拟考试T3】【PAT乙】1028 人口普查 (20分) 字符串比较

    problem 1028 人口普查 (20分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇 ...

  4. PAT乙级C语言 1028 人口普查

    思路 判断是否符合要求并计数,把符合的结构输入另一个数组,对该数组进行qsort排序,然后输出第一个和最后一个元素里的相关成员 推荐 我觉得这个写的很好(呜呜呜我写了七十几行人家写二十几行就好了,差距 ...

  5. PAT乙级1028 人口普查 (20 分)

    1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...

  6. 【PAT】1028 人口普查

    一.题目描述 PAT 1028 人口普查 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有 ...

  7. C++学习之路 | PTA乙级—— 1028 人口普查 (20 分)(精简)

    1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...

  8. PAT 1028 人口普查

    1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...

  9. PAT 乙 1028 人口普查

    1028. 人口普查(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 某城镇进行人口普查,得到了全体居民的 ...

  10. 1028 人口普查 (20 分)C++ 示例代码

    1028 人口普查 (20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超过 2 ...

最新文章

  1. matlab创建图形用户界面,Matlab 用户图形界面 基础 (一)
  2. 数字对 (长乐一中模拟赛day2T2)
  3. 手把手教你搭建一个基于Java的分布式爬虫系统
  4. (转)!注意:PreTranslateMessage弹出框出错
  5. mysql path conflict_yum安装MySQL出现conflict problem
  6. 两千块钱带来的 quot;希望quot;
  7. ubuntu简单的小命令
  8. setuptools find_packages
  9. setlength java_Java StringBuilder setLength()方法与示例
  10. 第七章:Servlet
  11. C#经典面试题及答案 (3)
  12. java 计划任务_Java实现定时任务的几种方案
  13. Parse分析之 -- Enum.Parse
  14. 播放.avi后缀视频报出0xc00d5212,编码格式不支持
  15. paypal支付开发接口(转)
  16. 《深入理解Java虚拟机》笔记04之垃圾收集算法
  17. 队列 front rear
  18. 移动硬盘未知usb设备(设定地址失败)
  19. JQueryUI自动补全 搜索提示实践
  20. networkx教程

热门文章

  1. AutoCAD 2007快捷键大全
  2. gcode 解析入门1-1
  3. 【图像分类】ResNet网络结构
  4. echarts自定义象形图,矢量图标
  5. mobi 电子书格式详解
  6. Vbs脚本编程简明教程之五
  7. 基于java+SpringBoot+HTML+Mysql)疫情防控微信小程序
  8. vivado 2018 下载地址
  9. Reactor 线程模型
  10. 常见linux软件下载地址