C語(yǔ)言輸出教學(xué)日歷表的方法實(shí)例
按照格式分別輸入學(xué)期,開(kāi)學(xué)時(shí)間,總周數(shù)即可得到課程表,以回車結(jié)束。
eg.
學(xué)期:2021-2022_2
開(kāi)學(xué)時(shí)間:2021/11/25
總周數(shù):20
輸出結(jié)果
#include<stdio.h> #include<windows.h> int Weekdayofyear(int year); int Isprime(int year); int Days(int year, int mouth); int Weekday(int year, int mouth, int day); int Max(int year,int mouth); int main() { char title1[] = "\t\txxxxxx大學(xué)教學(xué)日歷\t\t"; char title2[] = "0000-0000學(xué)年第0學(xué)期"; char tab[60] = "周 一 二 三 四 五 六 日"; char term3; char calender[100][8]; int tempday, tempmouth,flag = 1,b,c,d,e,f,g,h,i,j, cnt = 1, week,term1, term2,year, mouth, day; printf("學(xué)期:"); scanf("%d-%d_%c", &term1, &term2, &term3); printf("開(kāi)學(xué)時(shí)間:"); scanf("%d/%d/%d", &year, &mouth, &day);; printf("總周數(shù):"); scanf("%d", &week); tempday = day; tempmouth = mouth; for (b = 3; b >= 0; b--) { title2[b] = term1 % 10 + 48; term1 /= 10; } for (c = 8; c >= 5; c--) { title2[c] = term2 % 10 + 48; term2 /= 10; } title2[15] = term3; for (d = 0; d < week; d++) { calender[d][0] = d + 1; } for (e = 0; e < week; e++) { for (f = 1; f < 8; f++) { if (e == 0) { for (g = 1; g < Weekday(year, mouth, day); g++) { calender[e][g] = 0; } for (h = Weekday(year, mouth, day);h < 8; h++) { calender[e][h] = day++; } break; } if (day > Max(year, mouth)) { mouth += 1; if (mouth > 12) { mouth = 1; } calender[e][f] = -mouth; day = 2; } else { calender[e][f] = day++; } } } puts(title1); printf("\t\t "); puts(title2); puts(tab); for (i = 0; i < week; i++) { for (j = 0; j < 8; j++) { if (calender[i][j] == 0) { printf(" \t"); continue; } if (calender[i][j] < 0) { // SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 15 | 0 | 128 | 0); printf("%d月\t", -calender[i][j]); // SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 7 | 0 | 0 | 0); } else { printf("%2d\t", calender[i][j]); } } printf("\n"); } } int Weekdayofyear(int year) { int days = 0, week; int a; for (a = 0; a < year - 1900; a++) { if (a % 4 == 0) days += 366; else days += 365; } week = days % 7; if (week == 0) week = 7; return week; } int Isprime(int year) { char flag; if (year % 4 == 0) { flag = 1; } else { flag = 0; } return flag; } int Days(int year, int mouth) { int days = 0; int isprime; isprime = Isprime(year); switch (mouth) { case 12:days += 31; case 11:days += 30; case 10:days += 31; case 9:days += 30; case 8:days += 31; case 7:days += 31; case 6:days += 30; case 5:days += 31; case 4:days += 30; case 3:days += 31; case 2:if (isprime == 1) days += 29; else days += 28; case 1:days += 31; } return days; } int Weekday(int year, int mouth, int day) { int days; int weekday; days = Days(year, mouth - 1); days += day; weekday = days % 7; weekday = weekday + Weekdayofyear(year) - 1; if (weekday > 7) weekday -= 7; return weekday; } int Max(int year,int mouth) { int days; int isprime; isprime = Isprime(year); switch (mouth) { case 12:days = 31; break; case 11:days = 30; break; case 10:days = 31; break; case 9:days = 30; break; case 8:days = 31; break; case 7:days = 31; break; case 6:days = 30; break; case 5:days = 31; break; case 4:days = 30; break; case 3:days = 31; break; case 2:if (isprime == 1) days = 29; else days = 28; break; case 1:days = 31; break; } return days; }
VS版本
#include<stdio.h> #include<windows.h> int Isprimeofyear(int year) { //判斷是否為閏年 char flag; if (year % 4 == 0) { flag = 1; } else { flag = 0; } return flag; } int Weekdayofyear(int year) { //1900年1月1日是星期一,判斷這一年的1月1日是星期幾 int days = 0, week; for (int i = 0; i < year - 1900; i++) { if (i % 4 == 0) days += 366; else days += 365; } week = days % 7; if (week == 0) week = 7; return week; } int Mouthofdays(int year, int mouth) { //輸出月份到年初有多少天 int days = 0; int isprime; isprime = Isprimeofyear(year); switch (mouth) { case 12:days += 31; case 11:days += 30; case 10:days += 31; case 9:days += 30; case 8:days += 31; case 7:days += 31; case 6:days += 30; case 5:days += 31; case 4:days += 30; case 3:days += 31; case 2:if (isprime == 1) days += 29; else days += 28; case 1:days += 31; } return days; } int Weekdayofday(int year, int mouth, int day) { //返回輸入時(shí)間的星期數(shù) int days; int weekday; days = Mouthofdays(year, mouth - 1); days += day; weekday = days % 7; weekday = weekday + Weekdayofyear(year) - 1; if (weekday > 7) weekday -= 7; return weekday; } int Maxofmouth(int year,int mouth) { //返回一個(gè)月最多有多少天 int days; int isprime; isprime = Isprimeofyear(year); switch (mouth) { case 12:days = 31; break; case 11:days = 30; break; case 10:days = 31; break; case 9:days = 30; break; case 8:days = 31; break; case 7:days = 31; break; case 6:days = 30; break; case 5:days = 31; break; case 4:days = 30; break; case 3:days = 31; break; case 2:if (isprime == 1) days = 29; else days = 28; break; case 1:days = 31; break; } return days; } int main() { int year, mouth, day; char title1[] = "\t\txxxxxx大學(xué)教學(xué)日歷\t\t"; char title2[] = "0000-0000學(xué)年第0學(xué)期"; char tab[60] = "周 一 二 三 四 五 六 日"; int term1, term2; char term3; int week; char calender[100][8]; int cnt = 1; int tempday, tempmouth; int flag = 1; printf("學(xué)期:"); scanf_s("%d-%d_%c", &term1, &term2, &term3); //輸入學(xué)期 printf("開(kāi)學(xué)時(shí)間:"); scanf_s("%d/%d/%d", &year, &mouth, &day);; printf("總周數(shù):"); scanf_s("%d", &week); tempday = day; tempmouth = mouth; for (int i = 3; i >= 0; i--) //把輸入的int型的學(xué)期數(shù)轉(zhuǎn)化為char型存入(替代0)title2中以打印 { title2[i] = term1 % 10 + 48; term1 /= 10; } for (int j = 8; j >= 5; j--) //同上 { title2[j] = term2 % 10 + 48; term2 /= 10; } title2[15] = term3; //同上 for (int i = 0; i < week; i++) { calender[i][0] = i + 1; } for (int i = 0; i < week; i++) { for (int j = 1; j < 8; j++) { if (i == 0) { //日歷第一行同部星期數(shù) for (int k = 1; k < Weekdayofday(year, mouth, day); k++) { calender[i][k] = 0; } for (int k = Weekdayofday(year, mouth, day); k < 8; k++) { calender[i][k] = day++; } break; } if (day > Maxofmouth(year, mouth)) { mouth += 1; if (mouth > 12) { mouth = 1; } calender[i][j] = -mouth; day = 2; } else { calender[i][j] = day++; } } } puts(title1); printf("\t\t "); puts(title2); puts(tab); for (int i = 0; i < week; i++) { //輸出表格 for (int j = 0; j < 8; j++) { if (calender[i][j] == 0) { printf(" \t"); continue; } if (calender[i][j] == tempday && flag == 1) { printf("\b\b\b%d.%d.%d ", year, tempmouth, tempday); flag = 0; continue; } if (calender[i][j] < 0) { SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 15 | 0 | 128 | 0); //前景色|背景色|前景加強(qiáng)|背景加強(qiáng) printf("%d月\t", -calender[i][j]); SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 7 | 0 | 0 | 0); } else { printf("%2d\t", calender[i][j]); } } printf("\n"); } }
總結(jié)
到此這篇關(guān)于C語(yǔ)言輸出教學(xué)日歷表的文章就介紹到這了,更多相關(guān)C語(yǔ)言教學(xué)日歷表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++控制臺(tái)實(shí)現(xiàn)密碼管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++控制臺(tái)實(shí)現(xiàn)密碼管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11C++實(shí)現(xiàn)動(dòng)態(tài)順序表(vector)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)動(dòng)態(tài)順序表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05C語(yǔ)言實(shí)現(xiàn)學(xué)籍管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)學(xué)籍管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07Qt實(shí)現(xiàn)數(shù)據(jù)導(dǎo)出到xls的示例代碼
導(dǎo)入導(dǎo)出數(shù)據(jù)到csv由于語(yǔ)法簡(jiǎn)單,適用場(chǎng)景有限,于是本文將為大家介紹Qt如何實(shí)現(xiàn)導(dǎo)出數(shù)據(jù)到xls,感興趣的小伙伴可以跟隨小編一起試一試2022-01-01C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之二叉樹(shù)詳解
二叉樹(shù)(Binary tree)是樹(shù)形結(jié)構(gòu)的一個(gè)重要類型。許多實(shí)際問(wèn)題抽象出來(lái)的數(shù)據(jù)結(jié)構(gòu)往往是二叉樹(shù)形式。本文將通過(guò)示例詳細(xì)講解一下二叉樹(shù),需要的可以參考一下2022-03-03深入了解C語(yǔ)言中的字符串和內(nèi)存函數(shù)
本文主要帶大家來(lái)學(xué)習(xí)一些常用的庫(kù)函數(shù)。有了這些庫(kù)函數(shù),我們可以更加方便地操作字符串和內(nèi)存,從而提升我們的編碼效率。話不多說(shuō),我們開(kāi)始吧2022-11-11