题目1186:打印日期 题目9
2014-10-05 16:21
183 查看
这道题需要注意的是:年份输出的时候格式 %04d
题目描述:
给出年分m和一年中的第n天,算出第n天是几月几号。
输入:
输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。
输出:
可能有多组测试数据,对于每组数据,
按 yyyy-mm-dd的格式将输入中对应的日期打印出来。
样例输入:
样例输出:
#include <iostream>
#include <stdio.h>
#include <string>
#include <string.h>
#include <algorithm>
using namespace std;
//判断是否是闰年,是为true,不是为false
int IsRunNian(int iYear)
{
if (0 == iYear%400)
{
return 1;
}
if (0 == iYear%4 && 0 != iYear%100)
{
return 1;
}
return 0;
}
int iCount[2][12]={
31,28,31,30,31,30,31,31,30,31,30,31,
31,29,31,30,31,30,31,31,30,31,30,31
};
int main()
{
int iYear,iDay;
while (scanf("%d %d",&iYear,&iDay)!=EOF)
{
int iMonth=0,i=0;
int iIs=IsRunNian(iYear);
if (0==iIs&&366==iDay)
{
iYear++;iMonth=0;iDay=1;
}
else
{
for (i=0;i<12;i++)
{
if (iDay-iCount[iIs][iMonth]>0)
{
iDay-=iCount[iIs][iMonth];
iMonth++;
}
else
{
break;
}
}
}
printf("%04d-%02d-%02d\n",iYear,iMonth+1,iDay);
}
}
题目描述:
给出年分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
#include <iostream>
#include <stdio.h>
#include <string>
#include <string.h>
#include <algorithm>
using namespace std;
//判断是否是闰年,是为true,不是为false
int IsRunNian(int iYear)
{
if (0 == iYear%400)
{
return 1;
}
if (0 == iYear%4 && 0 != iYear%100)
{
return 1;
}
return 0;
}
int iCount[2][12]={
31,28,31,30,31,30,31,31,30,31,30,31,
31,29,31,30,31,30,31,31,30,31,30,31
};
int main()
{
int iYear,iDay;
while (scanf("%d %d",&iYear,&iDay)!=EOF)
{
int iMonth=0,i=0;
int iIs=IsRunNian(iYear);
if (0==iIs&&366==iDay)
{
iYear++;iMonth=0;iDay=1;
}
else
{
for (i=0;i<12;i++)
{
if (iDay-iCount[iIs][iMonth]>0)
{
iDay-=iCount[iIs][iMonth];
iMonth++;
}
else
{
break;
}
}
}
printf("%04d-%02d-%02d\n",iYear,iMonth+1,iDay);
}
}