C語言打印某一年的日歷
本文通過實(shí)例為大家分享了C語言打印某一年日歷的具體代碼,供大家參考,具體內(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ì)算出來距離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 };//用來標(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) {
//指針還沒有到左邊月份的第一天,應(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) {
//沒有日期要打印,打印四個(gè)空格
printf(" ");
}
else {
//有日期打印,打印日期
printf("%-4d", tag[i]);
}
}
printf("\n");
}
printf("\n");
}
}
int main() {
int year;//輸入年份,打印該年的日歷
scanf("%d", &year);
displayCalendar(year);
return 0;
}
運(yùn)行效果如下:

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++踩坑實(shí)戰(zhàn)之構(gòu)造和析構(gòu)函數(shù)
不論是構(gòu)造函數(shù),還是析構(gòu)函數(shù),都是C++、C#語言相對(duì)于其他語言而言特殊的地方,它是為了方便類中對(duì)象的初始化,這篇文章主要給大家介紹了關(guān)于C++踩坑實(shí)戰(zhàn)之構(gòu)造和析構(gòu)函數(shù)的相關(guān)資料,需要的朋友可以參考下2021-07-07
虛函數(shù)被類的構(gòu)造析構(gòu)函數(shù)和成員函數(shù)調(diào)用虛函數(shù)的執(zhí)行過程
虛函數(shù)被類的構(gòu)造析構(gòu)函數(shù)和成員函數(shù)調(diào)用虛函數(shù)的執(zhí)行過程,需要的朋友可以參考下2013-02-02
C語言超詳細(xì)講解隊(duì)列的實(shí)現(xiàn)及代碼
隊(duì)列(Queue)與棧一樣,是一種線性存儲(chǔ)結(jié)構(gòu),它具有如下特點(diǎn):隊(duì)列中的數(shù)據(jù)元素遵循“先進(jìn)先出”(First?In?First?Out)的原則,簡稱FIFO結(jié)構(gòu)。在隊(duì)尾添加元素,在隊(duì)頭刪除元素2022-04-04
c++元編程模板函數(shù)重載匹配規(guī)則示例詳解
這篇文章主要為大家介紹了c++元編程模板函數(shù)重載匹配規(guī)則示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

