【题1】KY19 今年的第几天?
描述
输入年、月、日,计算该天是本年的第几天。
输入描述:
包括三个整数年(1<=Y<=3000)、月(1<=M<=12)、日(1<=D<=31)。
输出描述:
输入可能有多组测试数据,对于每一组测试数据, 输出一个整数,代表Input中的年、月、日对应本年的第几天。
示例1
输入:
1990 9 20 2000 5 1
复制输出:
263 122
#include <cstdio>
//用空间换时间
//mday天数,totalday到n月的1月的天数,公式遍历12个月,闰年的判断
int main() {
int year,day,mon;
int totalday[13]={0};//到当月的1月1日总天数
int mday[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
for(int mon=2;mon<=12;++mon){
totalday[mon]=totalday[mon-1]+mday[mon-1];//到n月1日的和=到n-1月的1月1日+第n-1月的多少天
}
while (scanf("%d%d%d", &year, &mon, &day) != EOF) {
bool isleap= year%400==0 || year%100!=0 && year%4==0;
if(isleap==true&&mon>=3){
printf("%d\n",totalday[mon]+day+1);
} else{
printf("%d\n",totalday[mon]+day);
}
}
return 0;
}
【题2】KY222 打印日期
给出年分m和一年中的第n天,算出第n天是几月几号。
输入描述:
输入包括两个整数y(1=y=3000),n(1=n=366)。
输出描述:
可能有多组测试数据,对于每组数据, 按 yyyy-mm-dd的格式将输入中对应的日期打印出来。
示例1
输入
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>
//万能方案 (1)nextday 计算到目标日的天数 1月1日过n天后 ++day -> day=1 ++mon-> mon=1 ++year
//(2)闰年判断
int main() {
int year,n;//进行n次
int mon;
int mday[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
while(scanf("%d%d",&year,&n)!=EOF){
int mon=1;
int day=1;
for(int i=0;i<n-1;i++){//第1天是1月1,第三天是1月3 过了两天 。第n天 即n-1次
bool isleap=year%400==0||year%100!=0&&year%4==0;
if(isleap){
mday[2]=29;
} else{
mday[2]=28;
}
++day;
if(day>mday[mon]){
++mon;
day=1;
if(mon>12){
mon=1;
++year;
}
}
}
printf("%04d-%02d-%02d\n",year,mon,day);
}
return 0;
}