央视新闻发了一条微博,指出 2020 年有个罕见的“对称日”,即 2020 年 2 月 2 日,按照 年年年年月月日日 格式组成的字符串 20200202 是完全对称的。
给定任意一个日期,本题就请你写程序判断一下,这是不是一个对称日?
输入格式:
输入首先在第一行给出正整数 N(1< N≤10)。随后 N 行,每行给出一个日期,却是按英文习惯的格式:Month Day, Year。其中 Month 是月份的缩写,对应如下:
一月:Jan
二月:Feb
三月:Mar
四月:Apr
五月:May
六月:Jun
七月:Jul
八月:Aug
九月:Sep
十月:Oct
十一月:Nov
十二月:Dec
Day 是月份中的日期,为 [1, 31] 区间内的整数;Year 是年份,为 [1, 9999] 区间内的整数。
输出格式:
对每一个给定的日期,在一行中先输出 Y 如果这是一个对称日,否则输出 N;随后空一格,输出日期对应的 年年年年月月日日 格式组成的字符串。
输入样例:
5
Feb 2, 2020
Mar 7, 2020
Oct 10, 101
Nov 21, 1211
Dec 29, 1229
输出样例:
Y 20200202
N 20200307
Y 01011010
Y 12111121
N 12291229
代码长度限制16 KB
时间限制400 ms
内存限制64 MB
思路:将日期转换为字符串再翻转比较,要注意数据的补0
获取日期后先转换为string类,然后创造一个字符串,内容为需要补齐的0,然后与原来的相加,再翻转比较。
string Da_te=to_string(date);
string Date(8-Da_te.size(),'0');
Date+=Da_te;
Da_te=Date;
reverse(Da_te.begin(),Da_te.end());
完整代码如下:
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main(){
string Month[13]={"***","Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"};
int n;
cin>>n;
while(n--){
getchar();
int Mon,day,year,date;
string s,c;
cin>>s>>day>>c>>year;
for(int i=0;i<13;++i){
if(Month[i]==s){
Mon=i;
break;
}
}
date
=day+Mon*100+year*10000;
string Da_te=to_string(date);
string Date(8-Da_te.size(),'0');
Date+=Da_te;
Da_te=Date;
reverse(Da_te.begin(),Da_te.end());
if(Date==Da_te) cout<<"Y ";
else cout<<"N ";
cout<<Date<<endl;
}
return 0;
}