美文网首页
天花板编程手把手计划-第1期-第7天-打卡

天花板编程手把手计划-第1期-第7天-打卡

作者: Hans941 | 来源:发表于2017-05-18 16:09 被阅读0次

    题目

    请编程实现一个功能,输入任意一个日期,计算出那一天是星期几。这道题没有任何限制,你可以设计任何自己喜欢的交互形式,可以使用任何自己能想到的算法。

    解题思路

    因为之前写过打印任意年份日历的题,所以这道题相对难度较小。
    我们这次思考如何写一个让使用者感觉舒服的程序把。

    源码

    #include <stdio.h>
    #include <stdlib.h>
    #include <conio.h>
    
    void getDate(int *pYear, int *pMonth, int *pDay);//获取日期
    int checkDate(int year, int month, int day);//检查输入日期是否合格
    int calcWeekDay(int year, int month, int day);//计算当天星期数
    int leapYear(int year);//计算是否为闰年,是返回1,否返回0;参数(欲计算的年份)
    int yearWeekDays(int year);//返回本年首天周几的函数;参数(欲计算的年份)
    
    int g_monthDays[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
    
    void main()
    {
        int year, month, day;
        int weekday;
        getDate(&year, &month, &day);
        weekday = calcWeekDay(year, month, day);
        /*打印结果*/
        printf("\n\n\t\t\t\t\t\t  %d.%02d.%02d星期%d\n", year, month, day, weekday);
        printf("\n\n\t\t\t\t\t输入<ENTER>再次查询,其他任意键退出\n");
        fflush(stdin);   //获取字符前先清空缓冲区,也可以使用 rewind(stdin);
        if (getch() == 13)//如果输入是enter清屏再次查询,否则退出查询
        {
            system("cls");
            main();
        }
        else
        {
            exit(0);
        }
    }
    
    void getDate(int *pYear, int *pMonth, int *pDay)
    {
        while (1)
        {
            printf("\n\n\n\n");
            printf("\t\t\t\t**************************************************\n");
            printf("\t\t\t\t              任意日期查询星期数工具            \n\n");
            printf("\t\t\t\t                    年:");
            scanf("%d", pYear);
            printf("\t\t\t\t                    月: ");
            scanf("%d", pMonth);
            printf("\t\t\t\t                    日: ");
            scanf("%day", pDay);
            printf("\t\t\t\t**************************************************\n");
            if (checkDate(*pYear, *pMonth, *pDay))//如果输入合格跳出循环
            {
                break;
            }
            else
            {
                system("cls");
                printf("\n\n\n\t\t\t\t\t   输入日期不合格,请重新输入\n");
            }
        }
    }
    
    int checkDate(int year, int month, int day)//检查输入是否合格
    {
        if (year > 0 && month >= 1 && month <= 12 && day <= 31)
        {
            if (month == 2)//如果输入是二月是否合格
            {
                if (leapYear(year))
                {
                    if (day <= 29)
                    {
                        return 1;
                    }
                }
                else 
                {
                    if (day <= 28)
                    {
                        return 1;
                    }
                }
            }
            else if (month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12)
            {
                if (day <= 31)
                {
                    return 1;
                }
            }
            else
            {
                if (day <= 30)
                {
                    return 1;
                }
            }
    
        }
        return 0;
    }
    
    int calcWeekDay(int year, int month, int day)
    {
        int yearWeekDay, result;
        int days = 0;
        for (int i = 0; i < month - 1; i++)
        {
            days += g_monthDays[i];
        }
        days += day;
        if (leapYear(year) && month > 2)
        {
            days++;
        }
        yearWeekDay = yearWeekDays(year);
        result = yearWeekDay + (days - 1) % 7;
        result %= 7;
        return result;
    }
    
    int leapYear(int year)
    {
        if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
            return 1;
        else
            return 0;
    }
    
    int yearWeekDays(int year)
    {
        return ((year - 1) + (year - 1) / 4 - (year - 1) / 100 + (year - 1) / 400) % 7 + 1;
    }
    

    执行结果

    1 2 3

    总结

    现在再看上一期的21天代码训练营已经都能看懂了,试试继续跟着写那一个系列的程序把。

    相关文章

      网友评论

          本文标题:天花板编程手把手计划-第1期-第7天-打卡

          本文链接:https://www.haomeiwen.com/subject/wcvsxxtx.html