C++實現(xiàn)簡易萬年歷
更新時間:2019年10月30日 10:06:32 作者:Monarch666
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)簡易萬年歷,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C++實現(xiàn)簡易的萬年歷,供大家參考,具體內(nèi)容如下
代碼如下:
/* *文件名稱:萬年歷.cpp *作 者:chenghan *完成日期:2019/1/10 *版 本 號:1.0 *問題描述:制作一個簡單的萬年歷 */ #include<iostream> #include <string> using namespace std; //判斷一年是否為閏年,是返回true 否返回false bool isleapyear(int year); //兔子圖案 void Rabbit(); //封裝時間類 私有數(shù)據(jù)成員包括年月日 class Date { private: int year, month, day; //私有數(shù)據(jù)成員 public: Date(){} //無參的構(gòu)造函數(shù) Date(int year, int month, int day); //有參的構(gòu)造函數(shù) void Disp_Date(); //顯示星期數(shù) void set(); //用戶輸入時間 int week(); //判斷星期的函數(shù) void show(); //顯示日歷的函數(shù) }; //主函數(shù) int main() { Date t; //創(chuàng)建一個Date類對象 string N="yes"; Rabbit(); while(N=="yes"){ t.set(); //調(diào)用設(shè)置時間函數(shù) t.Disp_Date(); //顯示星期 t.show(); //展示日歷畫面 cout<<"\n是否繼續(xù)查詢,是(yes)否(no)\n"; cin>>N; } return 0; } //判斷一年是否為閏年,是返回true 否返回false bool isleapyear(int year) { if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) return true; else return false; } //兔子圖案 void Rabbit() { cout<<endl; cout<<" ┏━┓ ┏━┓"<<endl; cout<<"作者:chenghan ★│┃ ┃│┃"<<endl; cout<<" ┃│┗灬┛│┃"<<endl; cout<<"版本:1.0 ┃ ┃"<<endl; cout<<" ┃ ^ ^ ┃"<<endl; cout<<"時間:2019/1/10 ﹌ ˇ ﹌ "<<endl; cout<<" ┗○━━━○┛"<<endl; cout<<"---------------------------------\n"; cout<<"歡 來 萬 歷"<<endl; cout<<" 迎 到 年 !"<<endl; cout<<"---------------------------------------------------\n"; } //有參的構(gòu)造函數(shù) Date::Date(int year, int month, int day) //有參的構(gòu)造函數(shù) { this->year = year; this->month = month; this->day = day; } //顯示星期數(shù) void Date::Disp_Date(){ cout << year << "年" << month << "月" << day << "日 星期" ; switch(this->week()){ case 0: cout<<"日\n"; break; case 1: cout<<"一\n"; break; case 2: cout<<"二\n"; break; case 3: cout<<"三\n"; break; case 4: cout<<"四\n"; break; case 5: cout<<"五\n"; break; case 6: cout<<"六\n"; break; } } //用戶設(shè)置時間 void Date::set() { cout<<"請輸入您所想要查找的年、月、日:"; cin>>year>>month>>day; } //判斷星期的函數(shù) int Date::week(){ int C,y,d,M; if(this->month==1||this->month==2){ C = (this->year-1)/100; y = (this->year-1)%100; M = this->month+12; d = this->day; } else{ C = this->year/100; //C世紀(jì)數(shù)減一 y = this->year%100; //y年份后兩位 d = this->day; //d是日 M = this->month; } int W = C/4 - 2*C + y + y/4 + 13 * (M+1) / 5 + d - 1; //判斷星期的蔡勒公式 if (W < 0) /* 如果w是負(fù)數(shù),則計算余數(shù)方式不同 */ { W = 7 - (-W) % 7; return W; //返回值1~6對應(yīng)星期一到六 0對應(yīng)七 } else return W%7; } //顯示日歷的函數(shù) void Date::show(){ Date temp; temp.year = this->year; temp.month = this->month; temp.day = 1; int count = temp.week(); cout<<"---------------------------------------------------"<<endl; //粗制濫造的界面 cout<<"---------------------"<<this->year<<"年"<<this->month<<"月"<<"---------------------\n"; cout<<"日 一 二 三 四 五 六\n"; for(int i=0;i<count;i++){ cout<<" \t"; } if(temp.month == 1 ||temp.month == 3 ||temp.month == 5 || temp.month ==7 || temp.month ==8 || temp.month ==10 ||temp.month == 12){ for(int j=1;j<32;j++){ if(j<10)cout<<" "<<j<<"\t"; else cout<<j<<"\t"; if(count==6){ cout<<"\n"; count = 0; } else count++; } } else if(temp.month == 4 ||temp.month == 6 ||temp.month == 9 ||temp.month == 11){ for(int j=1;j<31;j++){ if(j<10)cout<<" "<<j<<"\t"; else cout<<j<<"\t"; if(count==6){ cout<<"\n"; count = 0; } else count++; } } else if(temp.month==2){ if(isleapyear(this->year)){ for(int j=1;j<30;j++){ if(j<10)cout<<" "<<j<<"\t"; else cout<<j<<"\t"; if(count==6){ cout<<"\n"; count = 0; } else count++; } } else{ for(int j=1;j<29;j++){ if(j<10)cout<<" "<<j<<"\t"; else cout<<j<<"\t"; if(count==6){ cout<<"\n"; count = 0; } else count++; } } } cout<<"\n---------------------------------------------------"; }
運行結(jié)果:
代碼中沒有檢查輸入錯誤的機制,寫的比較粗糙,有許多錯誤之處望指正。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言回溯法 實現(xiàn)組合數(shù) 從N個數(shù)中選擇M個數(shù)
在平時的算法的題目中,時常會遇到組合數(shù)相關(guān)的問題,暴力枚舉。在N個數(shù)中挑選M個數(shù)出來。利用for循環(huán)也可以處理,但是可拓展性不強,于是寫這個模板供以后參考2018-08-08