题目描述
设计一个日期(Date)类,其中有数据成员int year,month,dat;,有静态数据
成员数组int days[13];,用于分别存放一年12个月的天数,初始化为
{0,31,28,31,30,31,30,31,31,30,31,30,31}。在具体应用时,根据对象的成员
year年是否为闰年调整2月份的天数days[1]的值。请设计一个成员函数计算对
象的日期在当年是第几天。
类的成员函数可以设计如下:
Date(int Year=2000,int Month=1, int Day=1);//构造函数
void Set(int Year, int Month, int Day);
int isLeapyear();//判断是否为闰年(能被4整除不能被100整除或能被400整除),
int Days();//计算是该年的第几天
void Show();//显示年月日
并且,在类外编写一个测试函数:
void test(int y, int m, int d)
输入描述
输入数据有多组,每组占一行。假定所有的输入数据是合法的,不需考虑不合法数据。
输出描述
对于每组输入数据,输出一行,表示该日期是该年的第几天。
输入样例
2012 1 1
2012 2 1
2012 3 1
2012 4 1
2012 5 1
输出样例
是2012年的第1天
是2012年的第32天
是2012年的第61天
是2012年的第92天
是2012年的第122天
代码
#include<iostream>
using namespace std;
int Days[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
class data
{
private:
int y;
int m;
int d;
public:
data(int year = 2000, int month = 1, int day = 1)
{
y = year;
m = month;
d = day;
}
void set(int year, int month, int day);
int isleapyear(int y);
int days();
void show();
};
void data::set(int year, int month, int day)
{
y = year;
m = month;
d = day;
}
int data::isleapyear(int y)
{
if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0))
return 1;
else
return 0;
}
int data::days()
{
int f;
int a = 0;
f = isleapyear(y);
if (f ==1)
Days[2] = 29;
for (int i = 0; i<m; i++)
{
a += Days[i];
}
return a + d;
}
void data::show()
{
cout << "是" << y << "年的第" << days() << "天" << endl;
}
void test(int y, int m, int d)
{
data data;
data.set(y, m, d);
data.isleapyear(y);
data.show();
}
int main()
{
data data1;
int y, m, s;
while (cin>>y>>m>>s)
{
data1.set(y, m, s);
data1.days();
data1.show();
}
return 0;
}