趣味程序设计_打印日历

问题 K: 趣味程序设计_打印日历
时间限制: 1 Sec  内存限制: 128 MB
提交: 730  解决: 108
[提交][状态][讨论版]
题目描述

打印出任意年份的日历。提示:要判断该年份是否是闰年,若是闰年,二月为29天,平年为28天。而判断闰年的规则是:如果((该年能被4除尽且不能被100除尽) 或 能被400除尽),则该年是闰年。
输入

输入年份。
输出

与输入相对应,输出该年12个月的日历。
样例输入
2012
样例输出
*Mon Tue Wed Thu Fri Sat Sun
                           1
   2   3   4   5   6   7   8
   9  10  11  12  13  14  15
  16  17  18  19  20  21  22
  23  24  25  26  27  28  29
  30  31
*Mon Tue Wed Thu Fri Sat Sun
           1   2   3   4   5
   6   7   8   9  10  11  12
  13  14  15  16  17  18  19
  20  21  22  23  24  25  26
  27  28  29
*Mon Tue Wed Thu Fri Sat Sun
               1   2   3   4
   5   6   7   8   9  10  11
  12  13  14  15  16  17  18
  19  20  21  22  23  24  25
  26  27  28  29  30  31
*Mon Tue Wed Thu Fri Sat Sun
                           1
   2   3   4   5   6   7   8
   9  10  11  12  13  14  15
  16  17  18  19  20  21  22
  23  24  25  26  27  28  29
  30
*Mon Tue Wed Thu Fri Sat Sun
       1   2   3   4   5   6
   7   8   9  10  11  12  13
  14  15  16  17  18  19  20
  21  22  23  24  25  26  27
  28  29  30  31
*Mon Tue Wed Thu Fri Sat Sun
                   1   2   3
   4   5   6   7   8   9  10
  11  12  13  14  15  16  17
  18  19  20  21  22  23  24
  25  26  27  28  29  30
*Mon Tue Wed Thu Fri Sat Sun
                           1
   2   3   4   5   6   7   8
   9  10  11  12  13  14  15
  16  17  18  19  20  21  22
  23  24  25  26  27  28  29
  30  31
*Mon Tue Wed Thu Fri Sat Sun
           1   2   3   4   5
   6   7   8   9  10  11  12
  13  14  15  16  17  18  19
  20  21  22  23  24  25  26
  27  28  29  30  31
*Mon Tue Wed Thu Fri Sat Sun
                       1   2
   3   4   5   6   7   8   9
  10  11  12  13  14  15  16
  17  18  19  20  21  22  23
  24  25  26  27  28  29  30
*Mon Tue Wed Thu Fri Sat Sun
   1   2   3   4   5   6   7
   8   9  10  11  12  13  14
  15  16  17  18  19  20  21
  22  23  24  25  26  27  28
  29  30  31
*Mon Tue Wed Thu Fri Sat Sun
               1   2   3   4
   5   6   7   8   9  10  11
  12  13  14  15  16  17  18
  19  20  21  22  23  24  25
  26  27  28  29  30
*Mon Tue Wed Thu Fri Sat Sun
                       1   2
   3   4   5   6   7   8   9
  10  11  12  13  14  15  16
  17  18  19  20  21  22  23
  24  25  26  27  28  29  30
  31
提示

重点是要将某天对应星期几算出来,其它就只要搞好排版就行了。

关于求星期几,可以先找一个基准,比如1年1月1日是星期一,或1990年1月1日是星期一,然后按7天一个周期,计算出任意一天是星期几。当然,这还需要知道每个月有多少天,2月份还要看是否是闰年。

这题有意思的地方是每年第一天礼拜几的判断,是可以拿出来通用的;

#include <stdio.h>
int Judge(int n)
{
    if(((!(n%4))&&(n%100))||(!(n%400))) return 1; //是闰年
    else return 0;
}
int week(int n)
{
     int count=0;
     for(int i=1;i<n;i++)
     {
        if(Judge(i)) count+=2;
        else         count++;
     }
     int week =(1+count)%7==0? 7 :(1+count)%7;
     return week;
}
int main(void)
{
    int n;
    while(~scanf("%d",&n))
    {
        int year_begin = week(n);
        int day_begin = year_begin;
        int days;
        for(int i=1;i<=12;i++)
        {
            if(i==2&&Judge(n))                       days=29;
            else if(i==2&&!(Judge(i)))               days=28;
            else if((i<=7&&i%2)||(i>=8&&!(i%2)))         days=31;
            else                                     days=30;
            printf("*Mon Tue Wed Thu Fri Sat Sun\n");
            for(int j=1;j<=days;j++)
            {
                if(j==1)
                    for(int k=1;k<day_begin;k++) printf("    ");
                printf("%4d",j);
                if(++day_begin==8)
                {
                    if(j!=days) putchar('\n');
                    day_begin=1;
                }
            }
            putchar('\n');
        }
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值