天花板編程手把手計(jì)劃-第1期-第7天-打卡

題目

請(qǐng)編程實(shí)現(xiàn)一個(gè)功能,輸入任意一個(gè)日期,計(jì)算出那一天是星期幾。這道題沒(méi)有任何限制,你可以設(shè)計(jì)任何自己喜歡的交互形式,可以使用任何自己能想到的算法。

解題思路

因?yàn)橹皩?xiě)過(guò)打印任意年份日歷的題,所以這道題相對(duì)難度較小。
我們這次思考如何寫(xiě)一個(gè)讓使用者感覺(jué)舒服的程序把。

源碼

#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);//計(jì)算當(dāng)天星期數(shù)
int leapYear(int year);//計(jì)算是否為閏年,是返回1,否返回0;參數(shù)(欲計(jì)算的年份)
int yearWeekDays(int year);//返回本年首天周幾的函數(shù);參數(shù)(欲計(jì)算的年份)

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);
    /*打印結(jié)果*/
    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);   //獲取字符前先清空緩沖區(qū),也可以使用 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              任意日期查詢星期數(shù)工具            \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))//如果輸入合格跳出循環(huán)
        {
            break;
        }
        else
        {
            system("cls");
            printf("\n\n\n\t\t\t\t\t   輸入日期不合格,請(qǐng)重新輸入\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;
}

執(zhí)行結(jié)果

1
2
3

總結(jié)

現(xiàn)在再看上一期的21天代碼訓(xùn)練營(yíng)已經(jīng)都能看懂了,試試?yán)^續(xù)跟著寫(xiě)那一個(gè)系列的程序把。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 從今天起,我們要開(kāi)始學(xué)習(xí)用工程化的思想去解決問(wèn)題。之前,我們總是把所有的代碼寫(xiě)在一個(gè)源文件中,這樣看起來(lái)比較方便。...
    天花板閱讀 2,242評(píng)論 1 30
  • 上一篇中,我們布置了一道關(guān)于二維數(shù)組使用的練習(xí)題。大家做的都不錯(cuò),我們今天來(lái)仔細(xì)分析一下這道題目,看看有沒(méi)有你沒(méi)有...
    天花板閱讀 2,157評(píng)論 3 25
  • 1. 編程是一項(xiàng)綜合技能 1.1 編程和語(yǔ)言 之前的系列中,我們重點(diǎn)關(guān)注的是如何學(xué)會(huì)一門(mén)計(jì)算機(jī)語(yǔ)言。而在這個(gè)系列中...
    天花板閱讀 2,638評(píng)論 16 37
  • 上一篇中的課后練習(xí)大家普遍反映太簡(jiǎn)單了。其實(shí),麻雀雖小,五臟俱全。今天我們來(lái)看看它的解法。 1. 題目 請(qǐng)編程實(shí)現(xiàn)...
    天花板閱讀 1,630評(píng)論 2 17
  • 由于迷宮的問(wèn)題難度太大,有些人沒(méi)有及時(shí)完成,所以這一篇晚發(fā)出一天。通過(guò)迷宮的問(wèn)題,暴露出大家對(duì)遞歸掌握的不是很好,...
    天花板閱讀 1,589評(píng)論 6 16

友情鏈接更多精彩內(nèi)容