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-02C語言超詳細(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-04c++元編程模板函數(shù)重載匹配規(guī)則示例詳解
這篇文章主要為大家介紹了c++元編程模板函數(shù)重載匹配規(guī)則示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01