日期类的实现
文章目录
- 1. 日期类的具体实现
- 1.查询当前月份的天数
- 2. 构造函数的实现(注意)
- 3.d1==d2
- 4. d1!=d2
- 5. d1<d2
- 6. d1<=d2
- 7. d1>d2
- 8. d1>=d2
- 9. 日期+=天数
- 10.日期+天数
- 11.日期-=天数
- 12. 日期-天数
- 13. ++d和 d++
- 14. --d 和 d--
- 15.日期=日期 返回天数
- 2. 函数的声明——date.h
- 3. 函数的定义——date.cpp
- 4.函数调用——main.cpp
由于拆分了函数的声明和定义,所以在函数前面要加上date类,找到函数
1. 日期类的具体实现
1.查询当前月份的天数
int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
- 设置一个数组,下标对应月份,并把2月闰年的情况单拉出来
2. 构造函数的实现(注意)
date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) ) ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}
}
- 一定要注意日期传过来是否合法存在
3.d1==d2
bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
- 判断 年 月 日依次是否相等
4. d1!=d2
bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}
如果我们再次自己写就会有很多情况考虑,所以直接复用 d1==d2的取反
5. d1<d2
bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}
年小的为小,
年相等,月小为小
年 月相等,天小为小
其他情况都为false
6. d1<=d2
bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}
d1<=d2是由 d1==d2 和d1<d2 组成,分别复用两者即可实现
7. d1>d2
bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}
d1>d2的逻辑取反是 d1<=d2 ,由于d1<d2我们已经实现过了,只需要加上d1!=d2即可
8. d1>=d2
bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反
}
复用d1<d2的逻辑取反即可实现 d1>=d2
9. 日期+=天数
date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}
当day为负时,+= - 等价于-= ,所以调用-=的复用即可(-=实现在后面)
同样由于+=是对于本身操作,除了作用域还存在,所以使用引用返回
10.日期+天数
date date::operator+(int day)
{//注释的为第一种方法//由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{// getday -= getmonthday(ret._year, ret._month);// ret._month++;// if (ret._month == 13)// {// ret._year++;// ret._month = 1;// }//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;//方法二date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}
这里用了两种方法实现,但是可以发现第一种过于繁琐,只需复用上述+=,返回临时变量tmp即可
同样由于临时变量出了作用域就不存在了,所以使用传值返回
11.日期-=天数
date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this;}_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}
这里不太好想,如果当前日期月份的天数_day大于day,则直接return,若小于则会使_day为负进入循环,同时向上一个月借天数直到 _day<=0
若day为负,-=-等价于+= ,直接复用+=即可
12. 日期-天数
date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}
复用上面的-=即可,返回临时变量ret
13. ++d和 d++
date& date::operator++()//++d
{*this += 1;//复用+=return *this;
}
- 前置++是正常调用operator++,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator++(int)//d++
{date ret = *this;*this += 1;//复用+=return ret;
}
后置++因为同样是operator++,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回
14. --d 和 d–
date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}
- 前置- -是正常调用operator- -,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}
后置- -因为同样是operator- -,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回
15.日期=日期 返回天数
date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d)//复用<{max = d;min = *this;}int n = 0;while (min != max)//复用!={n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}
主要使用max和min两个临时变量,使min._day不断++,最终使max==min 结束返回计数n值
2. 函数的声明——date.h
#include<iostream>
using namespace std;
class date
{
public://函数声明int getmonthday(int year, int month);//查询当前月份的天数date(int year=1, int month=1, int day=1);//构造void print();//输出bool operator==(const date& d);//d1==d2bool operator!=(const date& d);//d1!=d2bool operator<(const date& d);//d1<d2bool operator<=(const date& d);//d1<=d2bool operator>(const date& d);//d1>d2bool operator>=(const date& d);//d1>=d2date operator+(int day);//日期+天数date& operator+=(int day);//日期+=天数date operator-(int day);//日期-天数date& operator-=(int day);//日期-=天数date& operator++();//++d//int 参数仅是为了占位,构成函数重载 区分前置date operator++(int);//d++date& operator--(); //--ddate operator--(int);//d--int operator-( date& d);//日期-日期 返回天数
private:int _year;int _month;int _day;
};
3. 函数的定义——date.cpp
#include"date.h"
//函数实现
int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) ) ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}}
void date::print()
{cout << _year << "-" << _month << "-" << _day << endl;
}
bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}
bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}
bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}
bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}
bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反
}date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}
date date::operator+(int day)
{由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{// getday -= getmonthday(ret._year, ret._month);// ret._month++;// if (ret._month == 13)// {// ret._year++;// ret._month = 1;// }//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this; }_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}
date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}
date& date::operator++()//++d
{*this += 1;return *this;
}
date date::operator++(int)//d++
{date ret = *this;*this += 1;return ret;
}date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d){max = d;min = *this;}int n = 0;while (min != max){n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}
4.函数调用——main.cpp
#include"date.h"
int main()
{date d1(2023, 2, 9);date d2(2023, 2, 1);cout << (d1==d2) << endl;cout << (d1 < d2) << endl;cout << (d1 - d2) << endl;return 0;
}
相关文章:
日期类的实现
文章目录1. 日期类的具体实现1.查询当前月份的天数2. 构造函数的实现(注意)3.d1d24. d1!d25. d1<d26. d1<d27. d1>d28. d1>d29. 日期天数10.日期天数11.日期-天数12. 日期-天数13. d和 d14. --d 和 d--15.日期日期 返回天数2. 函数的声明——date.h3. 函数的定义—…...

2022年这5款熟悉的软件退出了历史舞台
在过去的一年里,有很多新产品发布,当然也有很多产品与我们就此别过。这些产品曾陪伴我们的生活,给我们带来欢乐,帮助我们成长。所以本文将盘点一下在2022年和我们告别的产品。1.微软IE浏览器IE浏览器1995年8月16日正式上线&#x…...

用Nginx打包部署vue3项目及404和500解决
打包vue3 npm run build安装Nginx 这里安装步骤比较繁琐,现在服务器比较便宜,如果想用Nginx,可以去菜鸟教程https://www.runoob.com/linux/nginx-install-setup.html 配置安装一下找到安装路径下的 conf 文件夹 下 nginx.conf文件࿰…...

Java面试——多线程并发篇
✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…...

维基百科数据抽取
1. 数据路径 https://dumps.wikimedia.org/enwiki/latest/ ----英文 https://dumps.wikimedia.org/zhwiki/latest/ ----中文 https://dumps.wikimedia.org/enwiki/latest/enwiki-latest-pages-articles.xml.bz2 --下载最新的 https://dumps.wikimedia.org/wikidatawiki/2023…...

2020年因果推断综述《A Survey on Causal Inference》
最近阅读了TKDD2020年的《A Survey on Causal Inference》,传送门,自己对文章按照顺序做了整理,同时对优秀的内容进行融合,如有不当之处,请多多指教。 文章对因果推理方法进行了全面的回顾,根据传统因果框…...
嵌入式linux系统测试程序编写
文章目录 网络CPU load监测性能设定开源测试工具iozone —— 文件系统测试工具iperf —— 网络性能测试工具LMbench —— 系统性能评测LTP —— linux功能/性能压力测试memtester —— 内存测试,坏位检测stressapptest —— 内存流量压力测试stream —— 内存性能测试fio ——…...

力扣SQL刷题5
目录597. 好友申请 I:总体通过率602. 好友申请 II :谁有最多的好友603. 连续空余座位1045. 买下所有产品的客户597. 好友申请 I:总体通过率 官方讲的题目太繁琐了,大概就是(表2中列1列2不全相同的行数)/&a…...

动态规划详解(完结篇)——如何抽象出动态规划算法?以及解题思路
今天直接开始讲解FIRST:如何抽象出动态规划算法?这个问题,困扰了无数代OIER,包括本蒟蒻在比赛的时候,看一道题,怎么想到他是什么算法的呢?这就需要抽象能力而不同的算法,往往有着不同…...

C语言一维数组篇【下】——每日刷题经验分享
一维数组篇——每日刷题经验分享~😎前言🙌有序序列插入一个整数 😊序列中删除指定数字 😊序列中整数去重小乐乐查找数字筛选法求素数总结撒花💞😎博客昵称:博客小梦~ 😊最喜欢的座右…...

VHDL语言基础-组合逻辑电路-其它组合逻辑模块
目录 多路选择器: 逻辑功能: 常用的类型: 4选1多路选择器的实现: 求补器: 求补器的实现: 三态门: 三态门的应用实例: 三态门的实现: 缓冲器: 什么是…...

初识Vue
文章目录1. 前言2. Vue 的特点3. 安装 Vue4. HelloWord1. 前言 vue是什么 ? 引用 : vue.js 文档 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层…...

TOUGH系列软件建模实践方法及在地下水、CO2地质封存、水文地球化学、地热等多相多组分系统多过程耦合
查看原文>>> https://mp.weixin.qq.com/s?__bizMzAxNzcxMzc5MQ&mid2247578057&idx7&sn75f8d2c1c6edb28af76a8db4bb773de3&chksm9be2aed9ac9527cf0081082cdcf781e6c37f9f3ba383332ed1116abcbee0f05c0593187e964d&token2070450548&langzh_CN#r…...

Codeforces Round #699 (Div. 2)
E. 题意:n本书,每本书有颜色a[i],一次操作可以将其中一本书放在末尾,求满足:相同颜色的书都是相邻的 的最小操作次数. 显然最多只需要n次,考虑能节省多少次.倒着考虑,记f[i]为i~n最多能节约的次数.先预处理出每种颜色的出现的位置范围l[i],r[i]. 1.不节约这本书f[i] f[i 1]…...

MySQL存储过程的传参和流程控制
目录 一.存储过程传参—in 演示 二.存储过程传参—out 演示 三.存储过程传参—inout 演示 四.流程控制—判断 格式 演示 五.流程控制—case 语法 演示 六.流程控制—循环 循环—while 循环—repeat 循环—loop 一.存储过程传参—in in表示传入的参数,可以传…...

MySQl学习(从入门到精通11)
MySQl学习(从入门到精通11)第 14 章_视图1. 常见的数据库对象2. 视图概述2. 1 为什么使用视图?2. 2 视图的理解3. 创建视图3. 1 创建单表视图3. 2 创建多表联合视图3. 3 基于视图创建视图4. 查看视图5. 更新视图的数据5. 1 一般情况5. 2 不可…...
关于ThreadLocal
弱引用 1.1 java中的各种引用和测试: https://blog.csdn.net/thewindkee/article/details/102723838 1.2 treadlocal中的弱引用测试: https://blog.csdn.net/thewindkee/article/details/103726942 (这篇很重要) 内存泄露: https://zhuanlan.zhihu.com/p/523628871 综合考虑 …...

【C++】类和对象(中)
文章目录1. 类的6个默认成员函数2. 构造函数概念特性3. 析构函数概念特性4. 拷贝构造函数概念特征5. 运算符重载5.1 前置和后置重载5.2 赋值运算符重载6. 日期类的实现7. const成员8. 取地址及const取地址操作符重载1. 类的6个默认成员函数 如果一个类中什么成员都没有&#x…...
js下载文件
url为文件的src地址 url必须符合同源策略或者url的接口地址允许跨域,否则浏览器会报跨域错误 axios.get(data.url ,{ responseType: ‘blob’, }) .then( response>{ let blob new Blob([response.data]); let url window.URL.createObjectURL(blob); // 创建 …...

ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟
ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟 📍相关篇《ESP8266 + STC15基于AT指令通过TCP通讯协议获取时间》 📌ESP8266 AT固件基于安信可AT固件,相关刷AT固件可以参考《NodeMCU-刷写AT固件》 🔖STC15 单片机采用的是:STC15F2K60S2 晶振频率采用内部:22.11…...

深入剖析AI大模型:大模型时代的 Prompt 工程全解析
今天聊的内容,我认为是AI开发里面非常重要的内容。它在AI开发里无处不在,当你对 AI 助手说 "用李白的风格写一首关于人工智能的诗",或者让翻译模型 "将这段合同翻译成商务日语" 时,输入的这句话就是 Prompt。…...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...

大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
解锁数据库简洁之道:FastAPI与SQLModel实战指南
在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...

Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

c#开发AI模型对话
AI模型 前面已经介绍了一般AI模型本地部署,直接调用现成的模型数据。这里主要讲述讲接口集成到我们自己的程序中使用方式。 微软提供了ML.NET来开发和使用AI模型,但是目前国内可能使用不多,至少实践例子很少看见。开发训练模型就不介绍了&am…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...

【分享】推荐一些办公小工具
1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由:大部分的转换软件需要收费,要么功能不齐全,而开会员又用不了几次浪费钱,借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...