首页 > 编程语言 > 详细

2的幂位数大整数分治算法

时间:2015-04-13 23:04:41      阅读:438      评论:0      收藏:0      [点我收藏+]
#include <iostream>
#include <cstring>
#include <string>
#include <cstdio>

using namespace std;
//500 digits at most
struct Num{
    int num[1000],len;
    Num(){
        memset(num,0,sizeof(num));
        len=1;
    }
    Num(const string &s){
        len=s.size();
        for(int i=0;i<len;++i){
            num[i]=s[len-1-i]-'0';
        }
    }
    Num& operator=(const Num& right){
        copy(right.num,right.num+1000,this->num);
        len=right.len;
        return *this;
    }
    friend ostream& operator<<(ostream &os,const Num &output){
        for(int i=output.len-1;i>=0;--i)
            os<<output.num[i];
        return os;
    }
    friend Num operator+(Num &x,Num &y){
        Num ans;
        ans.len=max(x.len,y.len);
        for(int i=0;i<ans.len;++i){
            ans.num[i]=x.num[i]+y.num[i];
        }
        for(int i=0;i<ans.len;++i){
            ans.num[i+1]+=ans.num[i]/10;
            ans.num[i]%=10;
        }
        if(ans.num[ans.len]) ++ans.len;
        return ans;
    }
    friend Num operator-(const Num &left,const Num& right){
        Num ans;
        ans.len=max(left.len,right.len);
        for(int i=0;i<ans.len;++i)
            ans.num[i]=left.num[i]-right.num[i];
        for(int i=0;i<ans.len;++i){
            if(ans.num[i]<0){
                --ans.num[i+1];
                ans.num[i]+=10;
            }
        }
        while(ans.len>=1 && !ans.num[ans.len-1]) --ans.len;
        return ans;
    }
    friend Num mul(const Num &x,const Num &y){
        if(x.len==1 && y.len==1) return to_string(x.num[0]*y.num[0]);
        Num a,b,c,d,ans;
        int maxlen=max(x.len,y.len),len1=maxlen>>1;
        copy(x.num,x.num+len1,b.num);
        b.len=len1;
        copy(x.num+len1,x.num+maxlen,a.num);
        a.len=maxlen-len1;
        copy(y.num,y.num+len1,d.num);
        d.len=len1;
        copy(y.num+len1,y.num+maxlen,c.num);
        c.len=maxlen-len1;
        Num tem_ac=mul(a,c),tem_bd=mul(b,d),ac,bd,fin_cdab;
        Num cdab=mul(c+d,a+b)-tem_ac-tem_bd;
        copy(tem_ac.num,tem_ac.num+tem_ac.len,ac.num+len1*2);
        ac.len=tem_ac.len+2*len1;
        copy(cdab.num,cdab.num+cdab.len,fin_cdab.num+len1);
        fin_cdab.len=cdab.len+len1;
        ans=ac+fin_cdab;
        ans=ans+tem_bd;
        while(ans.len>1 && !ans.num[ans.len-1]) --ans.len;
        return ans;
    }
    friend Num operator*(const Num &x,const Num &y){
        return mul(x,y);
    }
};

int main()
{
    string a,b;
    while(cin>>a>>b){
        Num x=a,y=b;
        cout<<"***************************************************"<<endl;
        cout<<a<<endl<<"*"<<endl<<b<<endl<<"="<<endl<<x*y<<endl;
        cout<<"***************************************************"<<endl;
    }
    return 0;
}

2的幂位数大整数分治算法

原文:http://blog.csdn.net/fangpinlei/article/details/45030423

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!