复数的运算(类和对象)
Time Limit: 1000 ms Memory Limit: 65536 KiB
Problem Description
设计一个类Complex,用于封装对复数的下列操作:
成员变量:实部real,虚部image,均为整数变量;
构造方法:无参构造方法、有参构造方法(参数2个)
成员方法:含两个复数的加、减、乘操作。
复数相加举例: (1+2i)+(3+4i)= 4 + 6i
复数相减举例: (1+2i)-(3+4i)= -2 - 2i
复数相乘举例: (1+2i)*(3+4i)= -5 + 10i
要求:对复数进行连环运算。
Input
输入有多行。
第一行有两个整数,代表复数X的实部和虚部。
后续各行的第一个和第二个数表示复数Y的实部和虚部,第三个数表示操作符op: 1——复数X和Y相加;2——复数X和Y相减;3——复数X和Y相乘。
Output
计算数据输出其简化复数形式,如:-2-2i、-4、-3i、1+2i、0。
Sample Input
1 1 3 4 2 5 2 1 2 -1 3 0 2 2
Sample Output
5-7i
Hint
输入与输出形式示例:
如果输入:
2 3
-2 1 1
则输出:4i
如果输入:
1 2
-1 -2 1
则输出:0
复数的输出形式示例:
实部 虚部 输出形式
0 0 0
-4 0 -4
0 4 4i
3 2 3+2i
3 -2 3-2i
如果输入:
2 3
-2 1 1
则输出:4i
如果输入:
1 2
-1 -2 1
则输出:0
复数的输出形式示例:
实部 虚部 输出形式
0 0 0
-4 0 -4
0 4 4i
3 2 3+2i
3 -2 3-2i
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
int n,m;
int x,y,flag;
m = cin.nextInt();
n = cin.nextInt();
while(cin.hasNext()) {
x = cin.nextInt();
y = cin.nextInt();
flag = cin.nextInt();
if(flag==1) {
m+=x;
n+=y;
}
else if(flag==2) {
m-=x;
n-=y;
}
else if(flag==3) {
int m1=m,n1=n;
m = m1*x - n1*y;
n = m1*y + n1*x;
}
}
if(m==0&&n==0) {
System.out.println(0);
}
else
{
if(m!=0) {
System.out.printf("%d",m);//实部
}
if(m!=0&&n>0) {
System.out.printf("+"); //虚部
}
if(n!=0){
if(n==1) {
System.out.printf("i");
}
else if(n==-1) {
System.out.printf("-i");
}
else {
System.out.printf("%di",n);
}
}
}
cin.close();
}
}