第七周项目二友元类
来源:互联网 发布:杜兰特各赛季数据统计 编辑:程序博客网 时间:2024/05/01 05:51
/*Copyright (c)2016,烟台大学计算机与控制工程学院
02.*All rights reserved.
03.*文件名称:main.cpp
04.*作 者:徐聪
05.*完成日期:2016年4月17日
06.*版 本 号:v1.0
02.*All rights reserved.
03.*文件名称:main.cpp
04.*作 者:徐聪
05.*完成日期:2016年4月17日
06.*版 本 号:v1.0
07.*
问题描述:
友元类
程序代码:
#include <iostream>using namespace std;class Date; //对Date类的提前引用声明class Time{public: Time(int,int,int); void add_a_second(Date &); //增加1秒,1秒后可能会到了下一天,乃到下一月、下一年 void display(Date &); //显示时间,格式:月/日/年 时:分:秒private: int hour; int minute; int sec;};class Date{public: Date(int,int,int); friend class Time; //Time定义为Date的友元类private: int month; int day; int year;};int main( ){ Time t1(23,59,32); Date d1(2,28,2013); for(int i=0; i<=100; i++) { t1.add_a_second(d1); t1.display(d1); } return 0;}Time::Time(int h,int m,int s){ hour=h; minute=m; sec=s;}Date::Date(int m,int d,int y){ month=m; day=d; year=y;}int days(int m, int y); //days函数返回y年m月的天数void Time::add_a_second(Date &d){ if(++sec>=60) ++minute,sec-=60; if(minute>=60) ++hour,minute-=60; if(hour>=24) ++d.day,hour-=24; if(d.day>days(d.month,d.year)) ++d.month,d.day=1; if(d.month>12) ++d.year,d.month-=12;}void Time::display(Date &d){ cout<<d.year<<"年"<<d.month<<"月"<<d.day<<"日"; cout<<hour<<":"<<minute<<":"<<sec<<endl;}int days(int m, int y) //days函数返回y年m月的天数{ int d[]={0,31,28,31,30,31,30,31,31,30,31,30,31}; if((y%4==0&&y%100!=0)||(y%400==0)) d[2]=29; return d[m];}运行结果:
0 0
- 第七周项目二友元类
- 第七周项目二友元类
- 第七周—项目二友元类
- 第七周项目1
- 第七周项目一
- 第七周项目二
- 第七周项目一
- 第七周项目三
- 第七周项目一
- 第七周项目三友元类
- 第七周项目一
- 第七周项目二
- 第七周项目三
- 第七周项目四友元类
- 第七周项目五
- 第七周项目3
- 第七周项目1
- 第七周项目4
- windows DLL 被修改 案例分析
- hdoj5667 BestCoder Round #80 【费马小定理(膜拜)+矩阵快速幂+快速幂】
- mysql常见问答
- SMBIOS
- 病狗问题
- 第七周项目二友元类
- 一个简单的滑动门示例(附源码)
- Android组件-下拉列表、时间选择器、日期选择器、单选框、复选框
- Android控件架构与自定义控件(二)
- FZU 2225 小茗的魔法阵 (小模拟)
- 结构体的位域
- WARNING: Could not find jvm.cfg!
- USB device not found
- 算法课本~最大最小值经典算法和分值算法的实现