首页 > 其他分享 >打卡 复数的加减运算(运算符重载)

打卡 复数的加减运算(运算符重载)

时间:2023-04-20 19:22:13浏览次数:35  
标签:real CComplex image 运算符 复数 重载 打卡

###复数加减(运算符重载)

  1. 声明一个复数类CComplex(类私有数据成员为double型的real和image)
  2. 定义构造函数,用于指定复数的实部与虚部。
  3. 重载<<运算符,以格式real+image i的格式输出当前对象(当虚部为非负数时,实部虚部中间用+号连接,当虚部为负数时,实部虚部用-号连接:如3+4i,3-4i,3+0i)。
  4. 重载+运算符,实现两个复数对象之和(实部虚部分别相加)。
  5. 重载-运算符,实现两个复数对象的差(实部虚部分别相减)。

输入格式:
输入有两行:
第一行是复数c1的实部与虚部,以空格分隔;
第二行是复数c2的实部与虚部,以空格分隔。

输出格式:
输出共四行:
第一行是c1;
第二行是c2;
第三行是c1与c2之和;
第四行是c1与c2之差;

函数接口定义:

 
在这里描述类定义
class CComplex{...}
 

裁判测试程序样例:

 
#include <iostream>
using namespace std;

/* 请在这里填写答案 */

int main() {
    double r1,r2,i1,i2;
    cin>>r1>>i1;
    cin>>r2>>i2;
    CComplex c1(r1,i1),c2(r2,i2),c3,c4;
    cout<<c1;
    cout<<c2;
    c3=c1+c2;
    cout<<c3;
    c4=c1-c2;
    cout<<c4;
    return 0;
}
 

输入样例:

10 20
30 40
 

输出样例:

10+20i
30+40i
40+60i
-20-20i

思路:运算符重载,重载输入输出运算符需要将输入输出函数声明为友元函数

代码实现:

class CComplex{
public:
  CComplex(){real=0;image=0;}
  CComplex(double a, double b){ real=a, image=b;}
  friend istream &operator <<(istream & ,CComplex & );
  friend ostream &operator >>(ostream & ,CComplex & );
CComplex operator+(CComplex c) {
  return CComplex(real+c.real,image+c.image);
}
CComplex operator-(CComplex c){
  return CComplex(real-c.real,image-c.image);
}
  double real,image;
};
  istream &operator >>(istream & i,CComplex &c){
  i>>c.real>>c.image;
  return i;
}
  ostream &operator <<(ostream & o ,CComplex& c ){
  o<<c.real<<showpos<<c.image<<"i"<<noshowpos<<endl;
  return o;
}

 

标签:real,CComplex,image,运算符,复数,重载,打卡
From: https://www.cnblogs.com/qmz-znv2/p/17338046.html

相关文章

  • 打卡4
    问题描述:一俩卡车违反交通规则,撞人后逃跑。现场有三人目击该事件,但都没有记住车号,只记下车号的一些特征。甲说:牌照的前两位数字是相同的;乙说:牌照的后两位数字是相同的,但与前两位不同:丙是数学家,他说:四位的车号刚好是一个整数的平方。请根据以上线索求出车号。流程图: 伪代码:fo......
  • 打卡7
    1、最佳存款方案#include<stdio.h>intmain(){ doublemoney=0.0; for(inti=0;i<5;i++) money=(money+1000.0)/(1+0.063*12); printf("应存入的钱为%0.2f\n",money); return0;}2、冒泡排序法#include<stdio.h>#defineN10intmain(){ inta[N],temp; printf......
  • c++打卡第四天
    一、问题描述。有一对兔子,第三个月开始每月生一对兔子,刚出生的兔子经过三个月又可以生一对兔子,问从1月开始到n月,每月兔子的数量。二、设计思路。①、第一二个月都是一对兔子,第三个月是2对,3个月是三对,第四个月就是5对。②、由此可知,这个月兔子对数的总量等于前一个月和前两个月......
  • 关于Java中方法重载和方法重写
    方法重写是子类继承父类(默认继承Object类)后覆盖父类的方法需要保证同名同参同返回值且访问权限范围不能缩小(public>protected>default>private)publicclassFather{ publicintmethod(){ return-1; }}classSonextendsFather{ //访问范围不能小返回值方法......
  • 编程打卡
    #include<iostream>usingnamespacestd;#include<vector>#include<algorithm>typedefpair<int,int>PIIconstintN=300010;inta[N],s[N];vector<int>alls;//存储所有待离散化的值vector<PII>adds,query;//二分求出x对应的离散化的值intfind(in......
  • 4.20打卡
    #include<iostream>#include<iomanip>#include<cmath>usingnamespacestd;intmain(){inti,j;for(i=1;i<=9;i++){for(j=1;j<=i;j++){if(j<i){if(i*j/10!=0)......
  • 运算符
    运算符的种类: 算术运算符:+,-,*,/,%,++,--赋值运算符:=关系运算符:<,>,>=,<=,==,!=instanceof逻辑运算符:&&(与),||(或),!(非)位运算符:&,|,^,~,>>,<<,>>>条件运算符:?,:扩展赋值运算符:+=,-=,*=,/=  运算结果: ......
  • 每日打卡
    #include<iostream>usingnamespacestd;structqueue{ intdata[100];inthead;inttail;};intmain(){ structqueueq; inti; q.head=1; q.tail=1; for(i=1;i<=9;i++) { cin>>q.data[q.tail]; q.tail++; } whil......
  • 打卡 上课铃响之后 - C/C++ 多态
    如本章开篇所述,当小学里的上课铃响之后,学生(Student)、教师(Teacher)和校长(Principal)会对同一个消息表现出不同的行为。请设计Person、Student、Teacher以及Principal类,合理安排他们之间的继承关系并将所有类的bellRing()及析构函数设计为虚函数,使得下述代码可以正常执行并产生期望的......
  • leetcode_打卡08
    leetcode_打卡08题目:334.递增的三元子序列思路:分成左边L和右边R,只要找到该数左边比它小的,右边比他大的即可代码:classSolution{publicbooleanincreasingTriplet(int[]nums){intn=nums.length;int[]L=newint[n];int[]R=newint[n];......