原题链接:蓝桥杯算法提高VIP-任意年月日历输出
解题思路:
计算到目标日期天数,再对一周进行取模,得到的便是星期。输出星期前面空格时也很简单,就是上一题个月月末的星期。每个月的天数则可以用这个月的减去上个月的天数得到。
注意事项:
每周有7天,排列大于7天时需要换行。
另外,从每周的第一天从周末开始。
参考代码:
//1493: 任意年月日日历输出
#include <stdio.h>
int countDay(long year, long month)
{
long i, day = 0, days = 0;
if( month < 1 )
{
year --;
month = 12;
}
for( i = 2007; i < year; i++)
{
if( ( i % 4 == 0 && i % 100 != 0 ) || ( i % 400 == 0) )
day++;
}
days = ( year - 2007 ) * 365 + day;
if( ( year % 4 == 0 && i % 100 != 0 ) || ( i % 400 == 0) )
{
switch(month)
{
case 12: days += 31;
case 11: days += 30;
case 10: days += 31;
case 9: days += 30;
case 8: days += 31;
case 7: days += 31;
case 6: days += 30;
case 5: days += 31;
case 4: days += 30;
case 3: days += 31;
case 2: days += 29;
case 1: days += 31;
}
}
else
{
switch(month)
{
case 12: days += 31;
case 11: days += 30;
case 10: days += 31;
case 9: days += 30;
case 8: days += 31;
case 7: days += 31;
case 6: days += 30;
case 5: days += 31;
case 4: days += 30;
case 3: days += 31;
case 2: days += 28;
case 1: days += 31;
}
}
return days;
}
int main()
{
long year, month, days, day = 0, i, date = 0;
scanf("%ld %ld", &year, &month);
days = countDay(year, month);
printf("---------------------\n");
printf(" Su Mo Tu We Th Fr Sa\n");
printf("---------------------\n");
// 从上一月开始计算月末
if( year == 2007 && month == 1)
{
date = 0;
}
else
date = countDay(year, month - 1) % 7;
date++;
// 注意,日历表从周日开始
for( i = 0 ; i < date; i++ )
{
printf(" ");
}
for( i = 1; i <= ( countDay(year, month) - countDay(year, month - 1) ); i++)
{
printf("%3ld", i);
date ++;
if(date == 7)
{
printf("\n");
date = 0;
}
}
if(date != 0)
printf("\n");
printf("---------------------");
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复