zoukankan      html  css  js  c++  java
  • 高精度模板

    class Big{
        
        public:
            
            int size,num[2001];
            Big(){size=0;memset(num,0,sizeof num);}
            
            Big(int data){
                size=0;
                while(data!=0)
                {
                    size++;
                    num[size]=data%M;data/=M;
                }
            }
            
            inline void init(int data){
                size=0;
                while(data!=0)
                {
                    size++;
                    num[size]=data%M;data/=M;
                }
            }
            
            inline void copy(Big A){
                int s1=size,s2=A.size;
                size=s2;
                for(int i=s2;i>=1;i--) num[i]=A.num[i];
            }
    };
    
    inline int read()
    {
        int x=0,f=1;char c=getchar();
        while(c>'9'||c<'0'){if(c=='-')f=-1;c=getchar();}
        while(c>='0'&&c<='9'){x=x*M+c-'0';c=getchar();}
        return x*f;
    }
    
    Big operator + (Big A,Big B)
    {
        Big C;C.init(0);
        C.size=max(A.size,B.size);
        for(int i=1;i<=C.size;i++)
        {
            C.num[i]+=A.num[i]+B.num[i];
            C.num[i+1]+=C.num[i]/M,C.num[i]%=M;
        }
        if(C.num[C.size+1]!=0) C.size++;
        return C;
    }
    
    Big operator - (Big A,Big B)
    {
        Big C;
        C.size=max(A.size,B.size);
        for(int i=1;i<=C.size;i++)
        {
            C.num[i]+=A.num[i]-B.num[i];
            if(C.num[i]<0) C.num[i+1]--,C.num[i]+=M;
        }
        while(!C.num[C.size]) C.size--;
        return C;
    }
    
    Big operator * (Big A,Big B)
    {
        Big C;int s=A.size,s_=B.size;
        C.size=A.size+B.size;
        for(int i=1;i<=s;i++) for(int j=1;j<=s_;j++)
        {
            C.num[i+j-1]+=A.num[i]*B.num[j];
            if(C.num[i+j-1]>M) C.num[i+j]+=C.num[i+j-1]/M,C.num[i+j-1]%=M;
        }
        while(!C.num[C.size]) C.size--;
        return C;
    }
    
    Big operator /(Big A,int b)
    {
        Big C;
        int s1=A.size,k;k=s1;
        for(int i=s1;i>=1;i--)
        {
            C.num[i]=A.num[i]/b;
            if(i!=1) A.num[i-1]+=(A.num[i]%b*10);
            A.num[i]/=b;
        }
        while(k>=1 && C.num[k]==0) k--;C.size=k;
        return C;
    }
    
    ostream & operator << (ostream &os,Big A)
    {
        int s=A.size; os<<A.num[s];
        for(int i=s-1;i;i--) os<<setfill('0')<<setw(4)<<A.num[i];
        return os;
    }
    
    
    //说明
    赋值: Big A;A.init(x);//x为int
    Big A,B;A.copy(B);
    重载运算符
    折花枝,恨花枝,准拟花开人共卮,开时人去时。 怕相思,已相思,轮到相思没处辞,眉间露一丝。
  • 相关阅读:
    asp.net 重定向的三种方法
    C# 日期格式转【转】
    PL/SQL %TYPE和%ROWTYPE的区别【转】
    oracle 常用函数【转】
    阿里---arthas---代码诊断工具使用
    线上应用CPU占用过高
    Centos 7搭建Gitlab服务器超详细Centos 7搭建Gitlab服务器超详细(搭建成功)
    G1和CMS垃圾回收数据对比
    定位CPU暂用过高问题排查
    OAutho2----实现单点登录
  • 原文地址:https://www.cnblogs.com/L-Memory/p/7811597.html
Copyright © 2011-2022 走看看