15第六周项目五——友元类
来源:互联网 发布:销售网络的资源情况 编辑:程序博客网 时间:2024/06/05 23:40
/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:李晓凯
* 完成日期:2015年 4 月 12 日
* 版 本 号:v1.0
*
* 问题描述:
* 输入描述:
* 程序输出:
*/
代码:
#include <iostream>using namespace std;int days(int m,int y);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;};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 main( ){ Time t1(23,59,32); Date d1(2,28,2013); //测试时,再试试Date d1(2,28,2013)会如何 for(int i=0; i<=100; i++) { t1.add_a_second(d1); t1.display(d1); } return 0;}//下面定义两个类中的成员函数,要求不得再增加成员函数//注意体会在Time的成员函数中可以调用Date类的私有数据成员void Time::add_a_second(Date &d){ sec++; if(sec>59) { minute++; sec-=60; } if(minute>59) { hour++; minute-=60; } if(hour>23) { d.day++; hour-=24; } if(d.day>days(d.month,d.year)) { d.month++; d.day=1; } if(d.month>12) { d.month=1; d.year++; }}void Time::display(Date &d){ cout<<d.year<<"年"<<d.month<<"月第"<<d.day<<"天 "; cout<<hour<<":"<<minute<<":"<<sec<<endl;}int days(int m,int y){ 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
- 第六周项目五——友元类
- 第六周项目五——友元类
- 15第六周项目五——友元类
- 第六周 课后实践:项目五——友元类
- 第六周项目五:友元类
- 第六周 项目五:友元类
- 第六周项目五 友元类
- 第六周项目五--友元类
- 第六周项目五:友元类
- 第六周项目五 友元类
- 第六周项目五 友元类
- 第六周 项目五-友元类
- 第六周 项目五-友元类
- 第六周 项目五 友元类
- 第六周项目五 友元类
- 第六周项目五-友元类
- 第六周项目五 友元类
- 2015年第六周项目五:友元类
- UDP接收消息的第一次显示对端的IP地址是0.0.0.0
- MFC(8) 如何在工作线程中创建窗口?
- 荀彧之死与空盒子
- AIDL绑定远程服务
- Java-Tcp/Ip-CS时间问询UDP应用Demo
- 15第六周项目五——友元类
- 吝啬的国度
- JavaScript权威指南笔记5_类和模块
- 多边形区域填充算法--递归种子填充算法
- 链表 Add Two Numbers
- 数据存储与访问(1)-------------文件
- Android图片缩放总结及比较
- FFmpeg之Rtsp分析(一):Pause和seek
- MergeSort归并排序图文代码详解