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
你给出的代码整体结构是正确的,已经实现了复数类 `Complex` 和主类 `Main`,并满足了基本功能需求。但为了**确保代码完全正确、可运行且符合规范**,我会: 1. **分析现有代码的问题或潜在改进点** 2. **提供一个修复并优化后的完整版本** 3. **解释每一处修改的原因** --- ### ✅ 问题分析与改进建议 #### ❌ 存在的问题: | 问题 | 描述 | |------|------| | `addComp`, `multiComp`, `equalComp` 等方法命名不一致 | Java 习惯使用驼峰命名如 `add`、`multiply`,虽然 `addComp` 不算错,但冗余("Comp" 多余) | | `subComp` 是静态方法,调用方式特殊 | 虽然可以工作,但与其他实例方法不统一,不利于维护 | | `showComp()` 中对 `y == 0` 的处理输出只有实部数字,没有 `"i"` 是对的,但打印的是整数类型,可能格式混乱 | | 缺少空格和输出一致性 | 如 `c1=` 后直接接内容,建议统一风格 | --- ### ✅ 修复并优化后的完整 Java 代码(可直接提交) ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); // 输入四个整数:c1.x, c1.y, c2.x, c2.y Complex c1 = new Complex(sc.nextInt(), sc.nextInt()); Complex c2 = new Complex(sc.nextInt(), sc.nextInt()); Complex c3 = null; // 输出 c1 和 c2 System.out.print("c1="); c1.showComp(); System.out.print("c2="); c2.showComp(); // 加法:c1 + c2 c3 = c1.addComp(c2); System.out.print("c1+c2="); c3.showComp(); // 减法:c1 - c2(静态方法) c3 = Complex.subComp(c1, c2); System.out.print("c1-c2="); c3.showComp(); // 乘法:c1 * c2 c3 = c1.multiComp(c2); System.out.print("c1*c2="); c3.showComp(); // 相等比较 System.out.print("c1==c2:"); System.out.println(c1.equalComp(c2)); sc.close(); } } // 复数类定义 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; } // 显示复数为 a+bi 形式 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); // 只有实部 } } // 加法:作为实例方法 public Complex addComp(Complex c) { return new Complex(this.x + c.x, this.y + c.y); } // 减法:作为静态方法(保持原样) public static Complex subComp(Complex c1, Complex c2) { return new Complex(c1.x - c2.x, c1.y - c2.y); } // 乘法 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); } // 判断是否相等 public boolean equalComp(Complex c) { if (c == null) return false; return this.x == c.x && this.y == c.y; } } ``` --- ### ✅ 输入示例: ``` 5 8 3 -4 ``` ### ✅ 预期输出结果: ``` c1=5+8i c2=3-4i c1+c2=8+4i c1-c2=2+12i c1*c2=47+4i c1==c2:false ``` --- ### ✅ 关键说明: | 方法 | 类型 | 说明 | |------|------|------| | `addComp(c)` | 实例方法 | `c1.addComp(c2)` 更自然 | | `subComp(c1,c2)` | 静态方法 | `Complex.subComp(c1,c2)` 也合理,尤其适合操作符对称场景 | | `multiComp(c)` | 实例方法 | 统一风格更好 | | `equalComp(c)` | 实例方法 | 返回布尔值,用于判断 | > ⚠️ 注意:Java 中通常会重写 `equals(Object obj)`,但题目只要求 `equalComp`,所以保留即可。 --- ### ✅ 改进建议(可选增强) 如果你想进一步提升代码质量,可以考虑: 1. 将 `addComp` 改为 `add`,更简洁; 2. 使用 `@Override` 重写 `public boolean equals(Object obj)`; 3. 添加 `toString()` 方法以便支持 `System.out.println(c1)`; ```java @Override public String toString() { if (y == 0) return String.valueOf(x); else if (y > 0) return x + "+" + y + "i"; else return x + "" + y + "i"; } ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值