1051 复数乘法

复数可以写成 (A+Bi) 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 i​2​​=−1;也可以写成极坐标下的指数形式 (R×e​(Pi)​​),其中 R 是复数模,P 是辐角,i 是虚数单位,其等价于三角形式 (R(cos(P)+isin(P))。

现给定两个复数的 R 和 P,要求输出两数乘积的常规形式。

输入格式:

输入在一行中依次给出两个复数的 R​1​​, P​1​​, R​2​​, P​2​​,数字间以空格分隔。

输出格式:

在一行中按照 A+Bi 的格式输出两数乘积的常规形式,实部和虚部均保留 2 位小数。注意:如果 B 是负数,则应该写成 A-|B|i 的形式。

输入样例:

2.3 3.5 5.2 0.4

输出样例:

-8.68-8.23i

小坑:

题目中要求结果输出保留两位小数,若sumA,sumB位于0到-0.01之间,应该赋值为0(输出+0.00),否则输出-0.00

#include <bits/stdc++.h>

using namespace std;


int main()
{
    double a,b,c,d;
    double sumA,sumB;
    scanf("%lf%lf%lf%lf",&a,&b,&c,&d);
    sumA = a*cos(b) * c*cos(d) - a*sin(b) * c*sin(d);//a=(r1*r2)*cos(p1+p2);
    sumB = a*cos(b) * c*sin(d) + a*sin(b) * c*cos(d);//b=(r1*r2)*sin(p1+p2);
    if (fabs(sumA) < 0.01)
        sumA = 0;
    if (fabs(sumB) < 0.01)
        sumB = 0;
    if(sumB>=0)
        printf("%.2lf+%.2lfi\n",sumA,sumB);
    else
        printf("%.2lf-%.2lfi\n",sumA,fabs(sumB));
    return 0;
}

 

import java.util.Scanner; public class Main {     public static void main(String[] args) {         // TODO Auto-generated method stub         Scanner sc=new Scanner(System.in);    Complex c1=new Complex(sc.nextInt(),sc.nextInt());    Complex c2=new Complex(sc.nextInt(),sc.nextInt());         Complex c3=null;         System.out.print("c1=");         c1.showComp();               System.out.print("c2=");         c2.showComp();               c3=c1.addComp(c2);         System.out.print("c1+c2=");         c3.showComp();         c3=Complex.subComp(c1,c2);         System.out.print("c1-c2=");         c3.showComp();         c3=c1.multiComp(c2);         System.out.print("c1*c2=");         c3.showComp();         System.out.print("c1==c2:");         System.out.println(c1.equalComp(c2));     } } // your code // Complex 类实现 class Complex {     int x, y; // 实部和虚部     // 无参构造函数     public Complex() {         this.x = 0;         this.y = 0;     }     public Complex(int x, int y) {         this.x = x;         this.y = y;     }     public void showComp() {         if (y>0){             System.out.println(x+"+"+y +"i");         } else if (y<0) {             System.out.println(x+""+y +"i");         } else{             System.out.println(x);         }     }     // 复数加法:(a+bi) + (c+di) = (a+c) + (b+d)i     public Complex addComp(Complex c) {         return new Complex(this.x + c.x, this.y + c.y);     }     // 复数减法:(a+bi) - (c+di) = (a-c) + (b-d)i     static Complex subComp(Complex c1,Complex c2) {         return new Complex(c1.x - c2.x, c1.y - c2.y);     }     // 复数乘法:(a+bi) * (c+di) = (ac-bd) + (ad+bc)i     public Complex multiComp(Complex c) {         int real = this.x * c.x - this.y * c.y;         int imag = this.x * c.y + this.y * c.x;         return new Complex(real, imag);     }      // 比较两个复数是否相等     boolean equalComp(Complex c) {         return this.x == c.x && this.y == c.y;     } }
最新发布
12-29
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值