c++_运算符重载(时钟加减)

介绍

本文主要介绍 减号( - )、加号( + )、加等(+=)运算符重载并复现了时钟运行方式

源码

#include<iostream>using namespace std;class Time
{
public://加号计算函数void t_add(int& temp, const int& Right, bool& b){//判断时间是否大于 60if ((temp + Right) < 60)//当两数相加 小于60 则直接相加{temp += Right;b = 0;}else//当两数相加 大于60 则直接相加 后在减去60秒(分){temp += Right - 60;b = 1;}}//减号计算函数void t_sub(int& Left, const int& Right, bool& b){//判断左操作数是否大于右操作数if (Left > Right){//当左操作数大于右操作数则 直接两数相减Left -= Right;b = 0;}else{//当左操作数小于右操作数则 直接两数相减 后加上 60 秒(分)Left = (Left - Right) + 60;b = 1;}}//打印结果void print(){cout << "时间为:" << m_Hour << ":" << m_minute << ":" << m_second << endl;}
public://构造函数Time(int hour = 0, int minute = 0, int second = 0) :m_Hour(hour), m_minute(minute), m_second(second){}//加号重载Time operator+( const Time&Right){Time temp = *this;//用临时变量来接收 左操作数bool b = 0;//用来接收是否超过时间进制//秒针时间判断temp.t_add(temp.m_second, Right.m_second, b);if (b == 1)//b == 1代表秒针超过 60 秒了,需要分针加 1 分钟{/**************************************************利用 三目运算符 判断分针加 1 分针后是否超过 60 分针1.如果没超过则 “当前时间中 分针”加 1 分针2.如果超过则 “当前时间中 时针”加 1 小时**************************************************/(temp.m_minute + 1) < 60 ? (temp.m_minute += 1) : (temp.m_Hour += 1);}//分针时间判断temp.t_add(temp.m_minute, Right.m_minute, b);if (b == 1)//b == 1代表分针超过 60 分针了,需要时针加 1 小时{/**************************************************利用 三目运算符 判断时针加 1 小时后是否超过 24 小时1.如果没超过则 “当前时间中 时针”加 1 小时2.如果超过则归 0 小时**************************************************/(temp.m_Hour + 1) < 24 ? (temp.m_Hour += 1) : (temp.m_Hour = 0);}//时针时间判断/**************************************************利用 三目运算符 判断两个数相加是否超过 24 小时1.如果没超过则 相加两数,2.如果超过则 先相加两数,然后减 24 小时**************************************************/(temp.m_Hour + Right.m_Hour) < 24 ? (temp.m_Hour = temp.m_Hour + Right.m_Hour) : (temp.m_Hour = (temp.m_Hour + Right.m_Hour) - 24);b = 0;//初始化 bool	return temp;//返回临时变量}//减号重载Time operator-(const Time&Right){Time temp = *this;//用临时变量来接收 左操作数bool b = 0;//用来接收是否超过时间进制//秒针时间判断temp.t_sub(temp.m_second, Right.m_second, b);if (b == 1)//b == 1代表秒针超过 60 秒了,需要分针减 1 分钟{/*******************************************************判断减 1 分钟后是否小于等于 01.如果小于等于0 则先减 1 分针 在加 60 分钟,然后减 1 小时2.如果大于0 则减 1 分针*******************************************************/if ((temp.m_minute - 1) <= 0){temp.m_minute = (temp.m_minute - 1) + 60;temp.m_Hour -= 1;}else{temp.m_minute -= 1;}}//分针时间判断temp.t_sub(temp.m_minute, Right.m_minute, b);if (b == 1)//b == 1代表分针超过 60 分针了,需要时针减 1 小时{/*********************************************************利用 三目运算符 判断时针减 1 小时后小于等于 01.如果没超过则 “当前时间中 时针”减 1 小时,然后加 24 小时2.如果大于0 则减 1 小时*********************************************************/(temp.m_Hour - 1) <= 0 ? temp.m_Hour = (temp.m_Hour - 1) + 24 : temp.m_Hour -= 1;}//时针时间判断/*********************************************************利用 三目运算符 判断 两数相减 是否小于等于 01.如果没超过则 先相减两数,然后加 24 小时2.如果大于0 相减两数*********************************************************/(temp.m_Hour - Right.m_Hour) <= 0 ? temp.m_Hour = (temp.m_Hour - Right.m_Hour) + 24 : temp.m_Hour = temp.m_Hour - Right.m_Hour;b = 0;//初始化 bool	return temp;//返回临时变量}// += 重载(类内重载+=;效率高,因为类内直接返回操作数本身减少编译时间)Time& operator +=(Time&Right){*this = *this + Right;return *this;}
private:int m_Hour;//时针int m_minute;//分针int m_second;//秒针
};// += 重载(全局重载+=;效率低,需要重新构造一个左操作数会增加编译时间)
//Time& operator +=(Time&Left, const Time&Right)
//{
//	Left = Left + Right;
//	return Left;
//}
void main()
{// + 重载测试 结果 2:0:10Time t;Time t1(10, 20, 30);//设置初始时间10:20:30Time t2(15, 39, 40);//设置初始时间15:39:40t = t1 + t2;t.print();t1.print();t2.print();// - 重载测试 结果18:40:40cout << endl;Time t3(9, 20, 20);Time t4(14, 39, 40);t = t3 - t4;t.print();t3.print();t4.print();// += 重载测试cout << endl;t1 += t2;t1.print();system("pause");
}

运行结果

时间为:2:0:10时间为:17:39:50时间为:18:40:40
请按任意键继续. . .

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/594192.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言-浮点型数据在内存中的存储

目录 前言一、浮点数存储例子二、浮点数在内存的存储格式2.1 32位浮点数存储格式2.2 64位浮点数存储格式 三、IEEE 754对有效数字M和指数E的规定3.1 对存储有效数字M的规定3.2 对存储指数E的规定3.2.1 E在32位浮点数的存储格式3.2.2 E在64位浮点数的存储格式 3.3 对读取有效数M…

pythonnumpy六:高级功能:数组排序、数组连接、数组拆分等。

numpy是一个强大的Python库&#xff0c;提供了丰富的数组操作功能。下面我会详细介绍numpy中的数组排序、数组连接和数组拆分等功能。 1.数组排序&#xff1a; 使用np.sort()函数可以对数组进行升序排序。它返回一个新的已排序的数组。若要在原始数组上进行排序&#xff0c;可…

谷歌Gemini模型,碾压GPT-4!

谷歌Gemini 1.0革新&#xff0c;推出Gemini Ultra、Gemini Pro和Gemini Nano模型。Gemini Ultra强大但慢&#xff0c;Gemini Pro通用&#xff0c;Gemini Nano高效。Gemini模型在多领域与ChatGPT竞争&#xff0c;尤其Gemini Pro已应用于Bard。Gemini模型预计将在2024年通过Bard …

NLP论文阅读记录 - 2021 | SimCLS:抽象概括对比学习的简单框架

文章目录 前言0、论文摘要一、Introduction1.1目标问题1.2相关的尝试1.3本文贡献 二.相关工作2.1优势 三.本文方法——抽象概括的对比学习框架3.1 第一阶段&#xff1a;候选生成3.2 第二阶段&#xff1a;无参考评估3.3对比训练 四 实验效果4.1数据集4.2 对比模型4.3实施细节4.4…

【论文阅读】AADiff: Audio-Aligned Video Synthesis with Text-to-Image Diffusion

AADiff:基于文本到图像扩散的音频对齐视频合成。 code&#xff1a;没开源 paper&#xff1a;[2305.04001] AADiff: Audio-Aligned Video Synthesis with Text-to-Image Diffusion (arxiv.org) 一种新的T2V框架&#xff0c;额外使用音频信号来控制时间动态&#xff0c;使现成的…

MySQL中的六种日志你都懂么?不懂!那就必须看看

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

docker 安装可视化工具 Portainer 以及 汉化

安装portainer是最新版本&#xff0c;汉化指定版本2.9.1 。如果要安装汉化版&#xff0c;可直接跳转步骤四 一、拉去镜像 安装网址&#xff1a;Install Portainer BE with Docker on Linux - Portainer Documentation docker pull portainer/portainer二、根据portainer镜像创建…

常用rtmp、m3u8、flv、mp4直播流在线测试地址

✍️作者简介&#xff1a;小北编程&#xff08;专注于HarmonyOS、Android、Java、Web、TCP/IP等技术方向&#xff09; &#x1f433;博客主页&#xff1a; 开源中国、稀土掘金、51cto博客、博客园、知乎、简书、慕课网、CSDN &#x1f514;如果文章对您有一定的帮助请&#x1f…

CMake入门教程【基础篇】CMake+Linux gcc构建C++项目

文章目录 1.概述2.GCC与CMake介绍3.安装CMake和GCC4.代码示例 1.概述 在Linux环境下&#xff0c;使用CMake结合GCC&#xff08;GNU Compiler Collection&#xff09;进行项目构建是一种常见且高效的方法。CMake作为一个跨平台的构建系统&#xff0c;可以生成适用于不同编译器的…

面试经典150题(55-58)

leetcode 150道题 计划花两个月时候刷完&#xff0c;今天&#xff08;第二十四天&#xff09;完成了4道(55-58)150&#xff1a; 55.&#xff08;19. 删除链表的倒数第 N 个结点&#xff09;题目描述&#xff1a; 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff…

渗透第四天

常用的对称加密算法有&#xff1a;DES、3DES、RC2、RC4、AES 常用的非对称加密算法有&#xff1a;RSA、DSA、ECC 使用单向散列函数的加密算法&#xff08;摘要算法&#xff09;&#xff1a;MD5、SHA 密码存储加密 md5 32位或者16位 0-9 a-f 所组成的字符串 不可…

JWT+Redis 实现接口 Token 校验

1、业务逻辑 有一些接口&#xff0c;需要用户登录以后才能访问&#xff0c;用户没有登录则无法访问。 因此&#xff0c;对于一些限制用户访问的接口&#xff0c;可以在请求头中增加一个校验参数&#xff0c;用于判断接口对应的用户是否登录。 而对于一些不需要登录即可访问的接…

基于SSM的网络游戏交易平台设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

java常见面试题:什么是异常?Java中的异常有哪些分类?

异常是一个汉语词语&#xff0c;读音为y chng&#xff0c;指非正常的&#xff1b;不同于平常的&#xff1b;非常。在Java中&#xff0c;异常&#xff08;Exception&#xff09;是程序在运行过程中出现的不正常情况&#xff0c;例如除以零、数组越界等。异常分为两大类&#xff…

湖南大学-算法设计与分析-2023期末考试【原题】

前言 21&#xff1a;00刚刚结束的考试&#xff0c;凭着回忆把题目重现出来了&#xff0c;在复习的时候根本找不到往年的试卷&#xff0c;希望这张回忆的试卷能帮助到下一届的同学。知道题目基本上就能做出来了&#xff0c;但是不知道是真的做不出来&#xff0c;我就不给答案了…

【软件工程】走进敏捷开发:灵活、协作、迭代的软件工艺之旅

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; 软件工程 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言&#xff1a; 正文 敏捷开发&#xff08;Agile Development&#xff09; 详细介绍&#xff1a; 优缺点&#xff1a; 优点&#xf…

新概念英语第二册(17)

【New words and expressions】生词和短语&#xff08;5&#xff09; appear v. 登场&#xff0c;扮演 stage n. 舞台 bright adj. 鲜艳的 stocking n. &#xff08;女用…

【Mybatis】深入学习MyBatis:高级特性与Spring整合

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; Mybatis ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 高级特性 1 一级缓存和二级缓存 一级缓存 二级缓存 2 延迟加载 5 整合Spring 1 MyBatis-Spring模块 2 事务管理 结…

【Spark精讲】RDD缓存源码分析

面试题&#xff1a;cache后面能不能接其他算子&#xff0c;它是不是action操作&#xff1f; 能&#xff0c;不是action算子。 源码解析 RDD调用cache或persist之后&#xff0c;会指定RDD的缓存级别&#xff0c;但只是在成员变量中记录了RDD的存储级别&#xff0c;并未真正地…

SQL优化:物化视图

在前面一篇内容中&#xff0c;我们讲解了索引的创建。索引作为数据的目录&#xff0c;占用独立的存储空间&#xff0c;可以帮助我们提高查询的速度。 除了使用索引&#xff0c;还有一种方法可以加速查询&#xff0c;尤其是当我们的查询中使用了各种聚合函数&#xff0c;或者进…