题目
为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;
}