題目
為Date類實現如下成員:
構造器,可以初始化年、月、日。
大于、小于、等于(> 、< 、==)操作符重載,進行日期比較。
print() 打印出類似 2015-10-1 這樣的格式。
然后創建兩個全局函數:
第1個函數 CreatePoints生成10個隨機的Date,并以數組形式返回;
第2個函數 Sort 對第1個函數CreatePoints生成的結果,將其按照從小到大進行排序。
最后在main函數中調用CreatePoints,并調用print將結果打印出來。然后調用Sort函數對前面結果處理后,并再次調用print將結果打印出來。
class Date
{
int year;
int month;
int day;
};
- 作業要求
一,請使用正規編碼風格。
二,所有代碼寫在.h 和.cpp文件中,不要寫在word或txt等文件中。
三,請將作業以附件上傳的形式提交,請用你的Boolan賬號昵稱命名文件夾。
開工
- 首先是構造函數
date (int y=2000, int m=1, int d=1): year(y),month(m),day(d){}
- 然后是比較操作符重載
inline bool
operator > (const date& x, const date& y) {
if (x.gety() > y.gety()) return true ; //沒有定義 gety(x),所以不能用
if (x.gety() == y.gety() && x.getm() > y.getm()) return true;
if (x.gety() == y.gety()&& x.getm() == y.getm() && x.getd() > y.getd()) return true;
return false;
}
inline bool
operator < (const date& x, const date& y) {
if (x.gety() < y.gety()) return true ;
if (x.gety() == y.gety() && x.getm() < y.getm()) return true;
if (x.gety() == y.gety()&& x.getm() == y.getm() && x.getd() < y.getd()) return true;
return false;
}
inline bool
operator == (const date& x, const date& y) {
return x.gety() == y.gety() && x.getm() == y.getm() && x.getd() == y.getd();
}
inline bool
operator != (const date& x, const date& y) {
return x.gety() != y.gety() || x.getm() != y.getm() || x.getd() != y.getd();
}
- 然后是賦值操作
inline date
date::operator = (const date x) {
year=x.year;
month=x.month;
day=x.day;
return date(year,month,day);
}
- <<操作符重載以及 print 函數
#include <iostream>
using namespace std;
inline
ostream& operator << (ostream& os, const date& x) {
os << x.gety() << '-' << x.getm() << '-' << x.getd() << endl;
return os;
}
inline bool
date::print() {
cout << *this; //this 是指針
return 0;
}
- 最后類定義是這樣的
class date {
public:
date (int y=2000, int m=1, int d=1): year(y),month(m),day(d){}
date operator = (const date x);
int gety () const { return year;}
int getm () const { return month;}
int getd () const { return day;}
bool print();
private:
int year;
int month;
int day;
};
- CreatePoints 創建日期,偷了個小懶,生成的全是合法時期,所以沒有檢查的部分
class date {
public:
date (int y=2000, int m=1, int d=1): year(y),month(m),day(d){}
date operator = (const date x);
int gety () const { return year;}
int getm () const { return month;}
int getd () const { return day;}
bool print();
private:
int year;
int month;
int day;
};
- 搜索了一下冒泡法,然后把代碼套上去用
int Sort(date * x) {
date b;
for (int i=1;i<10;i++)
for (int j=0;j<10-i;j++)
if (x[j]>x[j+1])
{
b=x[j];
x[j]=x[j+1];
x[j+1]=b;
}// 冒泡法排序
return 0;
}
- 主體沒什么含量,就是兩個循環
int main(int argc, const char * argv[]) {
date* a;
a=CreatePoints();
for (int i=0;i<10;i++)
{
a[i].print();
}
cout << endl;
Sort(a);
for (int i=0;i<10;i++)
{
a[i].print();
}
delete[] a;
return 0;
}