3.28 c++

算数运算符

#include <iostream>
using namespace std;
class Num
{int rel;   //实部int vir;   //虚部
public:Num():rel(2),vir(1){}Num(int rel,int vir):rel(rel),vir(vir){}Num &operator=(const Num &other){cout << "Num的拷贝赋值函数" << endl;this->rel = other.rel;this->vir = other.vir;return *this;}friend Num operator+(const Num n1,const Num n2);friend Num operator-(const Num n1,const Num n2);friend Num operator*(const Num n1,const Num n2);friend Num operator/(const Num n1,const Num n2);friend Num operator%(const Num n1,const Num n2);Num operator+(const Num n1);Num operator-(const Num n1);Num operator*(const Num n1);Num operator/(const Num n1);Num operator%(const Num n1);void show();
};Num Num::operator+(const Num n1 )
{       Num temp;            temp.rel=this->rel+n1.rel;temp.vir=this->vir+n1.vir;return temp;
}
Num Num::operator-(const Num n1)
{Num temp;temp.rel=this->rel-n1.rel;temp.vir=this->vir-n1.vir;return temp;
}
Num Num::operator*(const Num n1)
{Num temp;temp.rel=this->rel*n1.rel;temp.vir=this->vir*n1.vir;return temp;
}
Num Num::operator/(const Num n1)
{Num temp;temp.rel=this->rel/n1.rel;temp.vir=this->vir/n1.vir;return temp;
}
Num Num::operator%(const Num n1)
{Num temp;temp.rel=this->rel%n1.rel;temp.vir=this->vir%n1.vir;return temp;
}//全局函数版的加法运算符重载
Num operator+(const Num n1,const Num n2)
{Num temp;temp.rel = n1.rel+n2.rel;temp.vir = n1.vir+n2.vir;return temp;
}
//减法
Num operator-(const Num n1,const Num n2)
{Num temp;temp.rel = n1.rel-n2.rel;temp.vir = n1.vir-n2.vir;return temp;
}
Num operator*(const Num n1,const Num n2)
{Num temp;temp.rel = n1.rel*n2.rel;temp.vir = n1.vir*n2.vir;return temp;
}
Num operator/(const Num n1,const Num n2)
{Num temp;temp.rel = n1.rel/n2.rel;temp.vir = n1.vir/n2.vir;return temp;
}
Num operator%(const Num n1,const Num n2)
{Num temp;temp.rel = n1.rel%n2.rel;temp.vir = n1.vir%n2.vir;return temp;
}
void Num::show()
{cout << rel << "+" << vir << "i" << endl;
}
int main()
{Num n1;Num n2(1,4);Num n3;n3 = n1+n2;n3.show();return 0;
}

关系运算符

#include <iostream>using namespace std;
class Num
{int rel;   //实部int vir;   //虚部
public:Num():rel(2),vir(1){}Num(int rel,int vir):rel(rel),vir(vir){}Num &operator=(const Num &other){cout << "Num的拷贝赋值函数" << endl;this->rel = other.rel;this->vir = other.vir;return *this;}friend bool operator>(const Num n1,const Num n2);friend bool operator>=(const Num n1,const Num n2);friend bool operator<(const Num n1,const Num n2);bool operator<=(const Num n1);bool operator==(const Num n1);bool operator!=(const Num n1);
};
bool operator>(const Num n1,const Num n2)
{if(n1.rel>n2.rel)  {return n1.rel>n2.rel;}else if(n1.rel==n2.rel)  {return n1.vir>n2.vir;}return n1.rel>n2.rel;
}
bool operator>=(const Num n1,const Num n2)
{if(n1.rel>n2.rel)  {return n1.rel>=n2.rel;}else if(n1.rel==n2.rel)  {return n1.vir>=n2.vir;}return n1.rel>=n2.rel;
}
bool operator<(const Num n1,const Num n2)
{if(n1.rel<n2.rel)  {return n1.rel<n2.rel;}else if(n1.rel==n2.rel)  {return n1.vir<n2.vir;}return n1.rel<n2.rel;
}
bool Num::operator<=(const Num n1)
{if(this->rel<n1.rel)  {return this->rel<=n1.rel;}else if(this->rel==n1.rel)  {return this->vir<=n1.vir;}return this->rel<=n1.rel;
}
bool Num::operator==(const Num n1)
{if(this->rel==n1.rel)  {return this->vir==n1.vir;}return this->rel==n1.rel;
}
bool Num::operator!=(const Num n1)
{if(this->rel!=n1.rel)  {return this->rel!=n1.rel;}else if(this->rel==n1.rel)  {return this->vir!=n1.vir;}return this->rel!=n1.rel;
}
int main()
{return 0;
}

逻辑运算符

#include <iostream>using namespace std;
class Num
{int rel;   //实部int vir;   //虚部
public:Num():rel(2),vir(1){}Num(int rel,int vir):rel(rel),vir(vir){}Num &operator=(const Num &other){cout << "Num的拷贝赋值函数" << endl;this->rel = other.rel;this->vir = other.vir;return *this;}friend bool operator&&(const Num n1,const Num n2);friend bool operator||(const Num n1,const Num n2);};
bool operator&&(const Num n1,const Num n2)
{if(n1.rel&&n2.rel){return n1.vir&&n2.vir;}return n1.rel&&n2.rel;
}
bool operator||(const Num n1,const Num n2)
{if(n1.rel||n2.rel){return n1.vir||n2.vir;}return n1.rel||n2.rel;
}
int main()
{cout << "Hello World!" << endl;return 0;
}

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

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

相关文章

Linux(CentOS)/Windows-C++ 云备份项目(结项,项目总结)

项目名称&#xff1a;云备份系统 项目功能&#xff1a; 搭建云备份服务器和客户端。 客户端程序运行在Windows下&#xff0c;将指定的目录下的文件备份到服务器上&#xff0c;并且支持浏览器下载&#xff0c;查看。 其中下载支持断点续传&#xff0c;服务器对备份文件进行热…

java ssh 电影院购票管理系统eclipse开发mysql数据库MVC模式java编程网页设计

一、源码特点 JSP ssh 电影院购票管理系统是一套完善的web设计系统&#xff08;系统采用ssh框架进行设计开发&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用 B/S模式开发。开发环境为TOMCAT…

C# 高级文件操作与异步编程探索(初步)

文章目录 文本文件的读写探秘StreamReader 类深度剖析StreamWriter 类细节解读编码和中文乱码的解决方案 二进制文件的读写BinaryReader 类全面解析BinaryWriter 类深度探讨 异步编程与C#的未来方向同步与异步&#xff1a;本质解读Task 的神奇所在async/await 的魔法 在现代编程…

推动制药行业数字化转型:基于超融合架构的MES一体机解决方案

随着中国对信息化重视程度的不断加深&#xff0c;制药行业作为国民经济的重要支柱之一&#xff0c;也在积极寻求通过数字化手段提升产业效率与产品质量。自党的十六大提出“以信息化带动工业化”的战略以来&#xff0c;制药业的这一转型探索尤为迫切。 在现代制药生产中&#…

【已修复】iPhone13 Pro 长焦相机水印(黑斑)修复 洗水印

iPhone13 Pro 长焦相机水印&#xff08;黑斑&#xff09;修复 洗水印 问题描述 iPhone13 Pro 后摄3倍相机有黑色斑点&#xff08;水印&#xff09;&#xff0c;如图所示&#xff0c; 后摄相机布局如图所示&#xff0c; 修复过程 拆机过程有风险&#xff0c;没有把握最好不要…

芒果YOLOv8改进145:全新风格原创YOLOv8网络结构解析图

&#x1f4a1;本篇分享一下个人绘制的原创全新风格 YOLOv8网络结构图 感觉搭配还行&#xff0c;看着比较直观。 该专栏完整目录链接&#xff1a; 芒果YOLOv8深度改进教程 订阅了专栏的读者 可以获取一份 <可以自行修改 / 编辑> 的 YOLOv8结构图修改源文件 YOLOv8结构图…

深入解析Oracle数据库中的分页查询原理及应用实战案例

在Oracle数据库中执行分页查询&#xff0c;尤其是大规模数据检索时&#xff0c;需要高效且精确地定位所需数据范围。 1. 使用 ROWNUM 分页查询 原理&#xff1a; ROWNUM是一个Oracle内建的伪列&#xff0c;它会为每个查询返回的行分配一个从1开始的连续行号。然而&#xff0c…

HackTheBox-Machines--Legacy

文章目录 1 端口扫描2 测试思路3 445端口漏洞测试4 flag Legacy 测试过程 1 端口扫描 nmap -sC -sV 10.129.227.1812 测试思路 目标开启了135、139、445端口&#xff0c;445 SMB服务存在很多可利用漏洞&#xff0c;所以测试点先从445端口开始。而且在Nmap扫描结果中&#xff0c…

项目四-图书管理系统

1.创建项目 流程与之前的项目一致&#xff0c;不再进行赘述。 2.需求定义 需求: 1. 登录: ⽤⼾输⼊账号,密码完成登录功能 2. 列表展⽰: 展⽰图书 3.前端界面测试 无法启动&#xff01;&#xff01;&#xff01;--->记得加入mysql相关操作记得在yml进行配置 配置后启动…

量化交易入门(二十五)什么是RSI,原理和炒股实操

前面我们了解了KDJ&#xff0c;MACD&#xff0c;MTM三个技术指标&#xff0c;也进行了回测&#xff0c;结果有好有坏&#xff0c;今天我们来学习第四个指标RSI。RSI指标全称是相对强弱指标(Relative Strength Index),是通过比较一段时期内的平均收盘涨数和平均收盘跌数来分析市…

03-Pandas的方法介绍

str.startwith()&#xff0c;用于检查列中的值是否以指定的字符串开头 df patients[patients[conditions].str.startswith("DIAB1") | patients["conditions"].str.contains(" DIAB1", regexFalse)]regexFalse代表不使用正则表达式进行匹配&…

3.28总结

1.java学习记录 1.方法的重载 重载换而言之其实就是函数名不变&#xff0c;但是其中的参数需要改变&#xff0c;可以三个方面改变&#xff08;参数类型&#xff0c;参数顺序&#xff0c;参数个数这三个方面入手&#xff0c;这样可以运用的&#xff09; 但是&#xff1a;注意…

2024.3.21|华北水利水电大学江淮校区ACM社团训练赛

2024.3.21|华北水利水电大学江淮校区ACM社团训练赛 1.数字拆解 2.矩阵修改 3.因子数 4.回文数 5.中位数 心有猛虎&#xff0c;细嗅蔷薇。你好朋友&#xff0c;这里是锅巴的C\C学习笔记&#xff0c;常言道&#xff0c;不积跬步无以至千里&#xff0c;希望有朝一日我们积累的滴…

通俗易懂:如何通过JVM参数来调整内存大小?

调整Java虚拟机&#xff08;JVM&#xff09;的内存大小主要是为了优化应用程序性能&#xff0c;防止内存不足而导致的OutOfMemoryError异常。以下是一些关键的JVM参数用于调整内存大小&#xff1a; 1. 堆内存&#xff08;Heap Memory&#xff09; - -Xms&#xff1a;设置JVM的初…

【联邦学习】kubefate安装(docker-compose版)

概念介绍 联邦学习&#xff1a;&#xff08;待补充&#xff09; fate介绍&#xff1a;&#xff08;待补充&#xff09; kubefate介绍&#xff1a;分布式版fate 官网&#xff1a;https://fate.fedai.org/ github&#xff1a;https://github.com/FederatedAI/ 安装 背景 本文…

springboot+vue在idea上面的使用小结

1.在mac上面删除java的jdk方法&#xff1a; sudo rm -rfjdk的路径 sudo rm -rf /Users/like/Library/Java/JavaVirtualMachines/corretto-17.0.10/Contents/Home 2.查询 Mac的jdk版本和路径&#xff1a; /usr/libexec/java_home -V 3.mac上面查询和关闭idea的网页端口&…

快速上手Spring Cloud五:Spring Cloud与持续集成/持续部署(CI/CD)

快速上手Spring Cloud 一&#xff1a;Spring Cloud 简介 快速上手Spring Cloud 二&#xff1a;核心组件解析 快速上手Spring Cloud 三&#xff1a;API网关深入探索与实战应用 快速上手Spring Cloud 四&#xff1a;微服务治理与安全 快速上手Spring Cloud 五&#xff1a;Spring …

samba实现linux共享文件夹

一、samba安装 sudo apt install samba 二、配置Samba 编辑Samba配置文件sudo vi /etc/samba/smb.conf 在文件末尾添加以下内容&#xff0c;设置一个简单的共享目录&#xff08;替换path_to_share为实际的共享目录路径&#xff09;&#xff1a; [Share] path /path_to_sha…

鱼眼相机的测距流程及误差分析[像素坐标系到空间一点以及测距和误差分析]

由于最近在整理单目测距的内容&#xff0c;顺手也总结下鱼眼相机的测距流程和误差分析&#xff0c;如果有错误&#xff0c;还请不吝赐教。 参考链接: 鱼眼镜头的成像原理到畸变矫正&#xff08;完整版&#xff09; 相机模型总结&#xff08;针孔、鱼眼、全景&#xff09; 三维…

多模态系列-综述MM-LLMs: Recent Advances in MultiModal Large Language Models

Homepage:https://mm-llms.github.io/ Paper: https://arxiv.org/abs/2401.13601 1 摘要 在过去的一年中,多模态大型语言模型(MM-LLMs)取得了实质性的进展,通过高效的训练策略,增强了现成的语言模型,以支持多模态输入或输出。由此产生的模型不仅保留了语言模型的固有…