C語言實(shí)現(xiàn)簡單萬年歷
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)簡單萬年歷的具體代碼,供大家參考,具體內(nèi)容如下
#include <stdio.h>
#include<stdlib.h>
int year, month;
int run[12] = { 31,29,31,30,31,30,31,31,30,31,30,31 };
int ping[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
char week[7][10] = { "SUN","MON","TUE","WED","THU","FRI","SAT" };
bool IsLeap(int year)
{
if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) //判斷閏年
{
return true;
}
else
{
return false;
}
}
void PrintStar()
{
printf("\t\t\t萬年歷\t\t\t\n");
printf("****************************************************\n");
for (int i = 0; i < 7; i++)
{
printf("%s\t", week[i]);
}
printf("\n");
}
int DaySum(int year, int month)
{
int sum = 0;
for (int i = 1990; i < year; i++)
{
if (IsLeap(i))
{
sum += 366;
}
else
{
sum += 365;
}
}
for (int i = 0; i < month - 1; i++)
{
if (IsLeap(year))
{
sum += run[i];
}
else
{
sum += ping[i];
}
}
return sum;
}
void PrintCal(int sum, int year, int month)
{
int nRes, nTmp;
nRes = sum % 7+1;//前面空幾格
nTmp = 7 - nRes;//從第幾格開始打印
for (int i = 0; i < nRes; i++)
{
printf("\t");
}
if (IsLeap(year))
{
for (int i = 1; i < run[month - 1]+1; i++)
{
printf("%d\t", i);
if (nTmp == i || (i - nTmp) % 7 == 0)
{
printf("\n");
}
}
printf("\n");
}
else
{
for (int i = 1; i < ping[month - 1]+1; i++)
{
printf("%d\t", i);
if (nTmp == i || (i - nTmp) % 7 == 0)
{
printf("\n");
}
}
printf("\n");
}
}
int main(void)
{
while (1)
{
scanf_s("%d %d", &year, &month);
PrintStar();
PrintCal(DaySum(year, month), year, month);
printf("****************************************************\n");
}
return 0;
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
類成員函數(shù)的重載、覆蓋與隱藏之間的區(qū)別總結(jié)
以下是對類成員函數(shù)的重載、覆蓋與隱藏之間的區(qū)別進(jìn)行了詳細(xì)的總結(jié)分析,需要的朋友可以過來參考下。希望對大家有所幫助2013-10-10
C++和python實(shí)現(xiàn)單鏈表及其原理
這篇文章主要介紹了C++和python實(shí)現(xiàn)單鏈表及其原理,單鏈表是鏈表家族中的一員,每個(gè)節(jié)點(diǎn)依舊由數(shù)據(jù)域(data)和指針域(next)組成,鏈表的具體概念下面文章將詳細(xì)介紹,需要的小伙伴可以參考一下2022-03-03
C++實(shí)現(xiàn)LeetCode(兩個(gè)有序數(shù)組的中位數(shù))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(兩個(gè)有序數(shù)組的中位數(shù)),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
Win32下C++實(shí)現(xiàn)快速獲取硬盤分區(qū)信息
這篇文章主要為大家詳細(xì)介紹了Win32下C++如何實(shí)現(xiàn)快速獲取硬盤分區(qū)信息,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-03-03
Qt物聯(lián)網(wǎng)管理平臺之實(shí)現(xiàn)自動(dòng)清理早期數(shù)據(jù)功能
隨著時(shí)間的增加,存儲(chǔ)的歷史記錄也在不斷增加,如果設(shè)備數(shù)量很多,存儲(chǔ)間隔很短,不用多久,數(shù)據(jù)庫中的記錄就非常多,至少是百萬級別起步,而且有些用戶還是需要存儲(chǔ)每一次的采集的數(shù)據(jù)。本文將利用Qt實(shí)現(xiàn)自動(dòng)清理早期數(shù)據(jù),需要的可以參考一下2022-07-07
Matlab實(shí)現(xiàn)多子圖同步調(diào)整視角
這篇文章主要為大家介紹了如何利用Matlab實(shí)現(xiàn)多子圖同步調(diào)整視角,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下2022-03-03

