题目1186:打印日期
总结,输出格式问题。
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:7047
解决:2447
-
题目描述:
-
给出年分m和一年中的第n天,算出第n天是几月几号。
-
输入:
-
输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。
-
输出:
-
可能有多组测试数据,对于每组数据,
按 yyyy-mm-dd的格式将输入中对应的日期打印出来。
-
样例输入:
-
2000 3 2000 31 2000 40 2000 60 2000 61 2001 60
-
样例输出:
-
2000-01-03 2000-01-31 2000-02-09 2000-02-29 2000-03-01 2001-03-01
-
答疑:
- 解题遇到问题?分享解题心得?讨论本题请访问: http://t.jobdu.com/thread-7909-1-1.html
-
- 思路也是类似,闰年判断,求和,格式输出,值得注意的是,最后的输出是YYYY-MM-DD的格式,所以要%04d%02d%02d才可以通过,上代码:
-
#include<iostream> #include<cstdio> #include<algorithm> using namespace std; int leap(int y){ if(y%400==0) return 1; else if(y%100==0) return 0; else if(y%4==0) return 1; else return 0; } int main(){ int day1[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; int day2[13]={0,31,29,31,30,31,30,31,31,30,31,30,31}; int y,n; while(cin>>y>>n){ if(leap(y)){ int sum=0;int m,d; for(int i=1;i<13;i++){ sum+=day2[i]; if(sum>=n){ m=i; d=n-(sum-day2[i]); break; } } printf("%04d-%02d-%02d\n",y,m,d); } else{ int sum=0;int m,d; for(int i=1;i<13;i++){ sum+=day1[i]; if(sum>=n){ m=i; d=n-(sum-day1[i]); break; } } printf("%04d-%02d-%02d\n",y,m,d); } } return 0; }
-
总结,输出格式问题。