设计一个日期类date,包括日期的年份,月份和日号,编写一个友元函数求两个日期之间相差的天数。

本文介绍了一个使用C++实现的日期计算类,该类能够处理日期的输入、显示及两个日期之间的天数计算。通过定义友元函数来辅助完成闰年的判断、计算指定日期到年初或年末的天数等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <iostream.h>
class date
{
 int year;
 int month;
 int day;
public:
 date(int y,int m,int d)
 {
  year=y;month=m;day=d;
 }
 void disp()
 {
  cout << year << "." << month << "." << day << endl;
 }
 friend int count_day(date &d,int);
 friend int leap(int year);
 friend int subs(date d1,date d2);
};
int count_day(date &d,int flag)
{
 static int day_tab[2][12]={{31,28,31,30,31,30,31,31,30,31,30,31},{31,29,31,30,31,30,31,31,30,31,30,31}};
 int p,i,s;
 if(leap(d.year))
  p=1;
 else
  p=0;
 if(flag)
 {
  s=d.day;
  for(i=1;i<d.month;i++)
   s+=day_tab[p][i-1];
 }
 else
 {
  s=day_tab[p][d.month]-d.day;
  for (i=d.month+1;i<=12;i++)
   s+=day_tab[p][i-1];
 }
 return(s);
}
int leap(int year)
{
 if(year%4==0 && year%100!=0 || year%400==0)
  return 1;
 else
  return 0;
}
int subs(date d1,date d2)
{
 int days,day1,day2,y;
 if(d1.year<d2.year)
 {
  days=count_day(d1,0);
  for(y=d1.year+1;y<d2.year;y++)
   if(leap(y))
    days+=366L;
   else
    days+=365L;
   days+=count_day(d2,1);
 }
 else if (d1.year==d2.year)
 {
  day1=count_day(d1,1);
  day2=count_day(d2,1);
  days=day2-day1;
 }
 else
 {
  days=count_day(d2,0);
  for(y=d2.year+1;y<d1.year;y++)
   if(leap(y))
    days+=366L;
   else
    days+=365L;
   days+=count_day(d1,1);
 }
 return days;
}
void main()
{
 
 date d1(2000,1,1),d2(2005,10,1);
 int ds1=subs(d1,d2),ds2=subs(d2,d1);
 cout << "日期d1:";d1.disp();
 cout << "日期d2:";d2.disp();
 cout << "d1和d2相距" << ds1 << "天" << endl;
    cout << "d2和d1相距" << ds2 << "天" << endl;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值