C語(yǔ)言打印某一年的日歷
本文通過(guò)實(shí)例為大家分享了C語(yǔ)言打印某一年日歷的具體代碼,供大家參考,具體內(nèi)容如下
輸入一個(gè)年份(1970以后的),以 2*6 的格式打印當(dāng)年的日歷。
主要思路:遍歷日期,根據(jù)日期標(biāo)記每一行應(yīng)該打印的內(nèi)容,存放到一個(gè)數(shù)組中,然后遍歷數(shù)組,根據(jù)數(shù)組的內(nèi)容逐行打印。代碼如下:
// 打印日歷
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
char month[12][10] = { "January", "February", "March", "April", "May", "June",
"July", "August", "September", "October", "November", "December" };
//計(jì)算某日期是當(dāng)年的第幾天
int day_in_year(int y, int m, int d) {
int r_day = 0;
int m_days[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };//每個(gè)月的天數(shù)
m_days[1] += y % 400 == 0 || y % 4 == 0 && y % 100 != 0;
for (int i = 0; i < m - 1; ++i) {
r_day += m_days[i];
}
r_day += d;
return r_day;
}
//計(jì)算某日是星期幾
int getWeek(int y, int m, int d) {
//先計(jì)算出來(lái)距離1970年1月1日周四有多少天
int days = 0; //當(dāng)日距離1970.1.1的天數(shù)
int res; //存放結(jié)果,周幾
if (y == 1970) {
days = day_in_year(y, m, d);
}
else {
for (int i = 1970; i < y; ++i) {
days = days + 365 + (i % 400 == 0 || i % 4 == 0 && i % 100 != 0);
}
days += (day_in_year(y, m, d) - 1);//因?yàn)樗愕氖蔷嚯x多少天,所以需要減一
}
//然后計(jì)算當(dāng)日是周幾
res = (days + 4) % 7;
return res;
}
//打印日歷
void displayCalendar(int y) {
int m_days[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };//每個(gè)月的天數(shù)
m_days[1] = 28 + (y % 400 == 0 || y % 4 == 0 && y % 100 != 0);
int week_l;//左邊月份的第一天是周幾
int week_r;//右邊月份的第一天是周幾
for (int m = 0; m < 6; ++m) {//m控制月份,比實(shí)際月份小1
//打印日歷的表頭
printf("%-12s %-12s\n", month[m], month[m + 6]);
printf("--------------------------- --------------------------- \n");
printf("Sun Mon Tue Wed Thu Fri Sat Sun Mon Tue Wed Thu Fri Sat \n");
week_l = getWeek(y, m + 1, 1);//求出左邊月份的第一天是星期幾
week_r = getWeek(y, m + 7, 1);//求出右邊列月份的第一天是星期幾
int date_l = 1;
int date_r = 1;
while (date_l <= week_l + m_days[m] || date_r <= week_r + m_days[m + 6]) {
//在范圍內(nèi),打印
int tag[15] = { 0 };//用來(lái)標(biāo)記應(yīng)該打印什么,整數(shù)表示打印日期,-1表示打印空格
tag[7] = -1;//左右界線
for (int p = 0; p < 7; ++p, ++date_l, ++date_r) {//p為tag的指針
//根據(jù)指針p給tag賦值
if (date_l <= week_l + m_days[m]) {
if (date_l < week_l) {
//指針還沒(méi)有到左邊月份的第一天,應(yīng)該打印空格
tag[p] = -1;
}
else {
//記錄應(yīng)該打印的日期
tag[p] = date_l - week_l;
}
}
else {//該打印的日期標(biāo)記完了,其他的用空格補(bǔ)上
tag[p] = -1;
}
//標(biāo)記右邊的情況,邏輯與左邊的一樣
if (date_r <= week_r + m_days[m + 6]) {
if (date_r < week_r) {
tag[p + 8] = -1;
}
else {
tag[p + 8] = date_r - week_r;
}
}
else {
tag[p + 8] = -1;
}
}
//一行一行打印
for (int i = 0; i < 15; ++i) {
if (tag[i] == -1||tag[i] == 0) {
//沒(méi)有日期要打印,打印四個(gè)空格
printf(" ");
}
else {
//有日期打印,打印日期
printf("%-4d", tag[i]);
}
}
printf("\n");
}
printf("\n");
}
}
int main() {
int year;//輸入年份,打印該年的日歷
scanf("%d", &year);
displayCalendar(year);
return 0;
}
運(yùn)行效果如下:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++ Primer 標(biāo)準(zhǔn)庫(kù)vector示例詳解
該文章主要介紹了C++標(biāo)準(zhǔn)庫(kù)中的vector類型,包括其定義、初始化、成員函數(shù)以及常見(jiàn)操作,文章詳細(xì)解釋了如何使用vector來(lái)存儲(chǔ)和操作對(duì)象集合,并提供了代碼示例來(lái)說(shuō)明vector的使用方法,感興趣的朋友一起看看吧2025-03-03
C語(yǔ)言內(nèi)存管理及初始化細(xì)節(jié)示例詳解
這篇文章主要為大家介紹了C語(yǔ)言內(nèi)存管理及初始化細(xì)節(jié)示例的詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02
C++實(shí)現(xiàn)掃雷小游戲(控制臺(tái)版)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)控制臺(tái)版的掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
C語(yǔ)言實(shí)現(xiàn)頁(yè)面置換 先進(jìn)先出算法(FIFO)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)頁(yè)面置換,先進(jìn)先出算法(FIFO),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
C語(yǔ)言深入探究選擇排序與基數(shù)排序使用案例講解
算法中排序是十分重要的,而每一個(gè)學(xué)習(xí)計(jì)算機(jī)的都會(huì)在初期的時(shí)候接觸到這種排序,下面這篇文章主要給大家介紹了關(guān)于c語(yǔ)言選擇排序與基數(shù)排序使用的相關(guān)資料,需要的朋友可以參考下2022-05-05

