复数幂
设i为虚数单位。对于任意正整数n,(2+3i)^n 的实部和虚部都是整数。
求 (2+3i)^123456 等于多少? 即(2+3i)的123456次幂,这个数字很大,要求精确表示。
答案写成 “实部±虚部i” 的形式,实部和虚部都是整数(不能用科学计数法表示),中间任何地方都不加空格,实部为正时前面不加正号。(2+3i)^2 写成: -5+12i,
(2+3i)^5 的写成: 122-597i
注意:需要提交的是一个很庞大的复数,不要填写任何多余内容。
考点:
1.大数类:在Java中有两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类, 至于两个类的对象能表示最大范围不清楚,理论上能够表示无限大的数, 只要计算机内存足够大。
2.文件输出:由于题目表明很庞大的复数,所以使用文件输出,原本 system.out 是系统 standard output stream, 默认是向控制台输出信息,但是通过System.setOut方法就可以将输出定向到其他的文件或者地方。 PrintStream:为其他输出流添加了功能,是他们能够方便的打印各种数据值的表现形式。① 永远不会抛出IOException,异常情况可通过checkError()方法测试的内部结构;②可自动刷新。这样得到的结果就直接可以从文件中粘贴即可。
3.规定复数的乘法按照以下的法则进行:
设z1=a+bi,z2=c+di(a、b、c、d∈R)是任意两个复数,那么它们的积(a+bi)(c+di)=(ac-bd)+(ad+bc)i。将A=(ac-bd),B=(ad+bc),(ac-bd)+(ad+bc)i=A+Bi,可继续迭代。
import java.io.File;
import java.io.FileNotFoundException;
import java.io.PrintStream;
import java.math.BigInteger;
/*
* 考点:大数类,文件输出
* 规定复数的乘法按照以下的法则进行:
设z1=a+bi,z2=c+di(a、b、c、d∈R)是任意两个复数,
那么它们的积(a+bi)(c+di)=(ac-bd)+(ad+bc)i。
将A=(ac-bd),B=(ad+bc),(ac-bd)+(ad+bc)i=A+Bi,可继续迭代
*/
public class 复数幂 {
public static void main(String[] args) throws FileNotFoundException {
/*
* 在Java中有两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类,
* 至于两个类的对象能表示最大范围不清楚,理论上能够表示无限大的数,
* 只要计算机内存足够大。
*/
BigInteger c = BigInteger.valueOf(2);//valueOf(parament)将参数转换为制定的类型将参数转换为指定的类型
BigInteger d = BigInteger.valueOf(3);
BigInteger a = BigInteger.valueOf(2);
BigInteger b = BigInteger.valueOf(3);
//(a+bi)*(c+di) = (a*c - b*d) + (a*d + b*c)i
for(int i=1;i<5;i++) {
//subtract()相减;multiply()相乘;add()大整数相加
BigInteger A = a.multiply(c).subtract(b.multiply(d));
BigInteger B = a.multiply(d).add(b.multiply(c));
a=A;//如果不设置临时变量,后面b的值会出错
b=B;
}
/*
* 原本 system.out 是系统 standard output stream,
* 默认是向控制台输出信息,但是通过System.setOut方法就可以将输出定向到其他的文件或者地方。
* PrintStream:为其他输出流添加了功能,是他们能够方便的打印各种数据值的表现形式。
1. 永远不会抛出IOException,异常情况可通过checkError()方法测试的内部结构;
2. 可自动刷新。
*/
PrintStream out = System.out;
PrintStream ps = new PrintStream(new File("D:/2018-3.txt"));//这时,系统的标志输出流就定向到了D盘2018-3.txt 文件中。
System.setOut(ps);//在指定文件中输出
if(b.compareTo(BigInteger.ZERO)>0) {
System.out.println(a.toString()+"+"+b.toString()+"i");
}else if(b.compareTo(BigInteger.ZERO)<0){
System.out.println(a.toString()+b.toString()+"i");
}
System.setOut(out);//在控制台输出
if(b.compareTo(BigInteger.ZERO)>0) {
System.out.println(a.toString()+"+"+b.toString()+"i");
}else if(b.compareTo(BigInteger.ZERO)<0){
System.out.println(a.toString()+b.toString()+"i");
}
}
}