java蓝桥复数幂

题目描述
设i为虚数单位。对于任意正整数n,(2+3i)^n 的实部和虚部都是整数。
求 (2+3i)^123456 等于多少? 即(2+3i)的123456次幂,这个数字很大,要求精确表示。

答案写成 “实部±虚部i” 的形式,实部和虚部都是整数(不能用科学计数法表示),中间任何地方都不加空格,实部为正时前面不加正号。(2+3i)^2 写成: -5+12i,
(2+3i)^5 的写成: 122-597i

注意:需要提交的是一个很庞大的复数,不要填写任何多余内容。
题目分析:根据复数的运算法则,由(2+3i)^2 为例:假设初始值2,3为a,b;
我们可以得出:(a+bi)^2 =(a+bi)*(2+3i)=(2a-3b)+(3a+2b)i;在将2a-3b赋予a;3a+2b赋予b进行计算,由于数值比较大,在Java中进行大数据BigInteger进行计算
代码如下:
import java.io.File;

import java.io.FileNotFoundException;
import java.io.PrintStream;
import java.math.BigInteger;

public class _复数幂 {

public static void main(String[] args) throws FileNotFoundException {
	// TODO Auto-generated method stub
	BigInteger two=BigInteger.valueOf(2);
	BigInteger three=BigInteger.valueOf(3);
	BigInteger a=BigInteger.valueOf(2);
	BigInteger b=BigInteger.valueOf(3);
	BigInteger a1=null;
	BigInteger b1=null;
	for(int i=0;i<12345;i++) {
		a1=a.multiply(two).subtract(b.multiply(three));//a1=2a-3b
		b1=a.multiply(three).add(b.multiply(two));//b1=3a+2b
		a=a1;
		b=b1;
	}
	//System.setOut(new PrintStream(new File("F:\\put.txt")));
	//在文本中输出
	System.out.println(a1+(b1.compareTo(BigInteger.ZERO)<0?"-":"+")+b1+"i");
	//(b1.compareTo(BigInteger.ZERO)<0?"-":"+") b1与0比较 <0则为-,大于0则为+
}

}
如有更好的算法,请多多指教!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值