给定公元2000年到公元3000年之间的某一天,请你给出该天的前天是哪一天。
链接:登录—专业IT笔试面试备考平台_牛客网牛客网是互联网求职神器,C++、Java、前端、产品、运营技能学习/备考/求职题库,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力https://ac.nowcoder.com/acm/contest/19304/Q
来源:牛客网
输入描述:
输入在一个日期,格式如"yyyy-mm-dd",题目保证所有输入日期为合法日期。
输出描述:
在一行中输出日期,格式如"yyyy-mm-dd"。
示例1
输入
复制
2020-11-15
输出
复制
2020-11-13
这道选择结构的练习题有着较强的综合性。
让我们快速步入正题———代码的讲解。
#include<iostream>
#include<stdio.h>
using namespace std;
int bool_year(int y)//判断输入年份是否是闰年
{
if(y<3000&&y>2000)//条件限制
{
if((y%4==0&&y%100!=0)||(y%400==0))//是闰年,返回1,否则,返回0.
return 1;
else
return 0;
}
return 0;
}
int main()//主函数
{
char str[11];
int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};//存储12个月份的date的数组
cin>>str;//输入为字符型
int y,m,d;//将年月日转换为整型数据
for(int i=0;i<4;i++)
y=y*10+(str[i]-'0');
for(int i=5;i<7;i++)
m=m*10+(str[i]-'0');
for(int i=8;i<10;i++)
d=d*10+(str[i]-'0');
if(bool_year(y)==1)//闰年判断
{
month[2]=29;//替换2月份的天数
if(d<3)//进行分组讨论,分为d<3和d>3的两种情况
{
if(m>=2)//由于d<3,输出月份数减一
{
m=m-1;
d=d+month[m]-2;
}
else if(m==1)//在一月份,输出年份数减一,m=12.
{
m=12;
y--;
d=d+month[m]-2;
}
}
else if(d>3)
{
d=d-2;
}
}
else//判断条件如上
{
if(d<3)
{
if(m>=2)
{
m=m-1;
d=d+month[m]-2;
}
else if(m==1)
{
m=12;
y--;
d=d+month[m]-2;
}
}
else if(d>3)
{
d=d-2;
}
}
printf("%04d-%02d-%02d\n",y,m,d);//输出格式控制。
}
这段程序只是我个人的一点浅见,如果有更好的解决方案,欢迎大家来评论区留言讨论。
- PS:牛客网是一个非常适合编程新手的训练网站。