分治算法-大整数相乘(JAVA实现)

 上大学算法分析实验课的内容.关于利用分治法大整数乘法.还没有解决大整数的存储方式,应该是要利用一维数组来解决.所以目前只是5位数的运算没有问题.程序健全

 1 /** */ /**
 2 * 大整数项乘
 3 * @author Administrator
 4 *
 5 */

 6 import  java.io.BufferedReader;
 7 import  java.io.InputStreamReader;
 8 import  java.io.IOException;
 9 import  java.math. * ;
10 public   class  Test1  {
11    public static void main(String[] args){
12        Test1 t1=new Test1();
13        
14        long x,y;
15        
16        System.out.println("Input x ");
17        x=t1.getNumFromConsole();
18        System.out.println("Input y ");
19        y=t1.getNumFromConsole();
20        System.out.println(t1.mult(x,y,num(x)));
21    }

22    public long getNumFromConsole(){
23        String str=null;
24        BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
25        try{
26            str=br.readLine();
27        }
catch(IOException ioe){
28            System.out.println(ioe.getMessage());
29        }

30        return Long.parseLong(str);
31    }

32    public long mult(long x,long y,int n){
33        long a,b,c,d,s;
34        int e;
35        if(n==1)
36            return x*y;
37        else{
38            a=(long)(x/Math.pow(10,n/2));//取x左半部分
39            b=(long)(x%Math.pow(10,n/2));//取x的又半部分
40            c=(long)(y/Math.pow(10,n/2));//取y的左半部分
41            d=(long)(y%Math.pow(10,n/2));
42            e=num(a);
43            s=(long)(mult(a,c,e)*Math.pow(10,n)+(mult((a-b),(d-c),e)+mult(a,c,e)+mult(b,d,e))*Math.pow(10, n/2)+mult(b,d,e));
44            return s;
45        }

46    }

47    //判断输入数字的位数
48    private static int num(long x){
49        int i=0;
50        if(x-9<=0)
51            return 1;
52        else{
53            while(x!=0){
54                i++;
55                x=x/10;
56            }

57            return i;
58        }

59    }
    
60}

61

其实应该用数组来保存大整数的,再考虑如何去完善这个程序。但分治算法的核心思想已经尽在其中了。  
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值