亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ps_zzn.cpp

?? 比較新的功能強大的rsa算法源代碼,方便使用.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
Ps_ZZn operator+(const Ps_ZZn& a,const Ps_ZZn& b)
{
    Ps_ZZn sum=a;
    sum+=b;
    return sum;
}

Ps_ZZn operator-(const Ps_ZZn& a,const Ps_ZZn& b)
{
    Ps_ZZn sum=a;
    sum-=b;
    return sum;
}

//
// In situ multiplication. Coeeficients in multiplicand
// are directly overwritten. Saves a lot of copying.
//

Ps_ZZn& Ps_ZZn::operator*=(Ps_ZZn& b)
{
    term_ps_zzn *ptr,*bptr;
    int g,d,deg,ka,kb;
    if (IsInt())
    {
        if (start!=NULL) *this = start->an*b;
        return *this;
    }
    if (b.IsInt())
    {
        if (b.start==NULL) clear();
        else *this *=(b.start->an);
        return *this;
    }
    g=igcd(pwr,b.pwr);
    deg=psN/g;


#ifdef FFT
    if (deg>=FFT_BREAK_EVEN)
    {
        big *A,*B;
        A=(big *)mr_alloc(deg,sizeof(big));
        B=(big *)mr_alloc(deg,sizeof(big));
        ka=pwr/g;
        decompress(ka);
        pad();
        ptr=start;
        while (ptr!=NULL)
        {
            d=ptr->n;
            if (d>=deg) break;
            A[d]=getbig(ptr->an);
            ptr=ptr->next;
        }
        kb=b.pwr/g;
        b.decompress(kb);
        bptr=b.start;
        while (bptr!=NULL)
        {
            d=bptr->n;
            if (d>=deg) break;
            B[d]=getbig(bptr->an);
            bptr=bptr->next;
       } 
       mr_ps_zzn_mul(deg,A,B,A);
       mr_free(B); mr_free(A);
       b.compress(kb);
    }
    else
    {
#endif
        *this=*this*b;
        return *this;
#ifdef FFT
    }
#endif
    norm();
    offset+=b.offset;
    return *this;
}

Ps_ZZn operator*(Ps_ZZn& a,Ps_ZZn& b)
{
    Ps_ZZn prod;
    ZZn t;
    term_ps_zzn *aptr,*bptr,*pos;
    int ka,kb,i,pa,pb,d,deg,g;

    if (a.IsInt())
    {
        if (a.start==NULL) return prod;
        else return (a.start->an*b);
    }

    if (b.IsInt())
    {
        if (b.start==NULL) return prod;
        else return (b.start->an*a);
    }

    g=igcd(a.pwr,b.pwr);

    deg=psN/g;

#ifdef FFT
    if (deg>=FFT_BREAK_EVEN)
    { // use fast methods
        big *A,*B,*C;
        A=(big *)mr_alloc(deg,sizeof(big));
        B=(big *)mr_alloc(deg,sizeof(big));
        C=(big *)mr_alloc(deg,sizeof(big));
        char *memc=(char *)memalloc(deg);
        for (i=0;i<deg;i++) C[i]=mirvar_mem(memc,i);
       
        ka=a.pwr/g;
        a.decompress(ka);

        aptr=a.start;
        while (aptr!=NULL)
        {
            d=aptr->n;
            if (d >= deg) break;
            A[d]=getbig(aptr->an);
            aptr=aptr->next;
        }
        kb=b.pwr/g;
        b.decompress(kb);
        bptr=b.start;
        while (bptr!=NULL)
        {
            d=bptr->n;
            if (d >= deg) break;
            B[d]=getbig(bptr->an);
            bptr=bptr->next;
        }
        mr_ps_zzn_mul(deg,A,B,C);
        pos=NULL;
        for (d=0;d<deg;d++)
        {
            t=C[d];
            if (t.iszero()) continue;
            pos=prod.addterm(t,d*g,pos);
        }
        memkill(memc,deg);
        a.compress(ka); b.compress(kb);
        mr_free(C); mr_free(B); mr_free(A); 
    }
    else
    {
#endif
        bptr=b.start;

        while (bptr!=NULL)
        {
            aptr=a.start;
            pb=bptr->n*b.pwr-b.offset;
            pos=NULL;
            while (aptr!=NULL)
            {
                pa=aptr->n*a.pwr-a.offset;
                if (pb+pa>=psN) break;
                pos=prod.addterm(aptr->an*bptr->an,pa+pb,pos);
                aptr=aptr->next;
            }
            bptr=bptr->next;
        }
#ifdef FFT
    }
#endif

    if (prod.start!=NULL) prod.offset=a.offset+b.offset;
    return prod;
}

Ps_ZZn operator/(const ZZn& num,const Ps_ZZn& b)
{
    Ps_ZZn quo;
    term_ps_zzn *pos=NULL;
    int pw=b.pwr;
    ZZn w,v0=b.cf(0);

    for (int n=0;n<psN/pw;n++)
    {
        if ((n*pw+b.offset)>=psN) break;
        if (n==0) w=num;
        else w=0;
        for (int k=0;k<n;k++)
            w-=quo.cf(k)*b.cf(n-k);
        pos=quo.addterm(w/v0,n,pos); 
    }

    quo.pwr=pw;
    quo.offset=(-b.offset);
    return quo;
}

Ps_ZZn operator/(Ps_ZZn& a,Ps_ZZn& b)
{
    Ps_ZZn quo;
    term_ps_zzn *pos=NULL;
    int ka,kb,pw;

    ka=a.pwr;
    kb=b.pwr;

    if (ka!=kb)
    {
        pw=1;
        a.decompress(a.pwr);
        b.decompress(b.pwr);
    }
    else pw=ka;

    ZZn w,v0=b.cf(0);

    for (int n=0;n<psN/pw;n++)
    {
        if (n*pw+b.offset-a.offset>=psN) break;
        w=a.cf(n);
        for (int k=0;k<n;k++)
            w-=quo.cf(k)*b.cf(n-k);
        pos=quo.addterm(w/v0,n,pos); 
    }
    if (ka!=kb)
    {
       a.compress(ka); 
       b.compress(kb);
    }
    else quo.pwr=pw;

    quo.offset=a.offset-b.offset;
    return  quo;
}

Ps_ZZn& Ps_ZZn::operator/=(const ZZn& x)
{
    term_ps_zzn *ptr=start;
    while (ptr!=NULL)
    {
        ptr->an/=x;
        ptr=ptr->next;
    }
    return *this;
}

Ps_ZZn& Ps_ZZn::operator/=(int m)
{
    term_ps_zzn *ptr=start;
    while (ptr!=NULL)
    {
        ptr->an/=m;
        ptr=ptr->next;
    }
    return *this;
}

Ps_ZZn operator/(const Ps_ZZn& a,const ZZn& b)
{
    Ps_ZZn quo;
    quo=a;
    quo/=b;
    return quo;
}

Ps_ZZn operator/(const Ps_ZZn& a,int m)
{
    Ps_ZZn quo;
    quo=a;
    quo/=m;
    return quo;
}


Ps_ZZn& Ps_ZZn::operator=(int m)
{
    clear();
    if (m!=0) addterm((ZZn)m,0);
    return *this;
}

Ps_ZZn& Ps_ZZn::operator=(const Ps_ZZn& p)
{
    term_ps_zzn *ptr;
    term_ps_zzn *pos=NULL;
    clear();
    int pw;

    pwr=p.pwr;
    offset=p.offset;
    ptr=p.start;
    while (ptr!=NULL)
    {
        pw=ptr->n*p.pwr-p.offset;
        if (pw>=psN) break;
        pos=addterm(ptr->an,pw,pos);
        ptr=ptr->next;
    }

    return *this;
}

Ps_ZZn& Ps_ZZn::operator*=(const ZZn& x)
{
    term_ps_zzn *ptr=start;
    if (x.iszero()) 
    {
        clear();
        return *this;
    }
    while (ptr!=NULL)
    {
        ptr->an*=x;
        ptr=ptr->next;
    }
    return *this;
}

Ps_ZZn operator*(const ZZn& z,const Ps_ZZn &p)
{
    Ps_ZZn r=p;
    r*=z;
    return r;
}

Ps_ZZn operator*(const Ps_ZZn &p,const ZZn& z)
{
    Ps_ZZn r=p;
    r*=z;
    return r;
}

Ps_ZZn pow(Ps_ZZn &a,int k)
{
    Ps_ZZn res;
    int w,e;

    if (k==0) 
    {
        res=1;
        return res;
    }
    res=a;
    if (k==1) return res;

    e=k; w=1;
    while (w<=e) w<<=1;
    w>>=1; 
    e-=w; w/=2;
    while (w>0)
    {
        res*=res;
        if (e>=w)
        {
            e-=w;
            res*=a;
        }
        w/=2;
    }
    res.offset*=k;
    
    return res;
}


Ps_ZZn power(const Ps_ZZn &a,int e)
{ // return f(a^e), e is +ve
    Ps_ZZn res;
    term_ps_zzn *ptr;
    term_ps_zzn *pos=NULL;

    ptr=a.start;
    while (ptr!=NULL)
    {
        if ((ptr->n*a.pwr)*e < psN)
        {
            pos=res.addterm(ptr->an,ptr->n,pos);
            ptr=ptr->next;
        }
        else break;
    }

    res.pwr=e*a.pwr;
    res.offset=e*a.offset;

    return res;
}

ostream& operator<<(ostream& s,const Ps_ZZn& p)
{
    BOOL first=TRUE;
    ZZn a;
    term_ps_zzn *ptr=p.start;
    int pw;

    if (ptr==NULL)
    {
        s << "0";
        return s;
    }

    while (ptr!=NULL)
    {
        a=ptr->an;
        if (a.iszero()) 
        {
            ptr=ptr->next;
            continue;
        }
        if ((Big)a < get_modulus()/2) 
        {
            a=(-a);
            s << " - ";
        }
        else if (!first) s << " + ";

        first=FALSE;
        pw=ptr->n*p.pwr-p.offset;
        if (pw==0)
        {
            s << a;
            ptr=ptr->next;
            continue;
        } 

        if (a==(ZZn)1) s << "x";
        else      s << a << "*x";
    
        if (pw!=1) s << "^" << pw;
        ptr=ptr->next;
    }
    return s;
} 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频你懂的| 欧美日韩一区二区在线视频| 午夜视频在线观看一区二区 | 亚洲精品成人精品456| 国产性天天综合网| 中文字幕成人av| 国产精品美女久久久久久久久| 欧美激情一二三区| 亚洲手机成人高清视频| 亚洲另类春色校园小说| 亚洲一区二区在线免费观看视频| 亚洲九九爱视频| 亚洲成人黄色小说| 日本欧美一区二区| 看国产成人h片视频| 精品亚洲免费视频| 成人免费毛片app| 91黄色激情网站| 欧美一区二区在线不卡| 久久久久亚洲蜜桃| 国产精品久久99| 亚洲18女电影在线观看| 久久精品国产澳门| 成人综合在线网站| 欧美网站一区二区| 欧美成va人片在线观看| 国产亚洲欧美激情| 亚洲一卡二卡三卡四卡五卡| 日本aⅴ亚洲精品中文乱码| 国产综合色视频| 日本高清免费不卡视频| 日韩欧美亚洲国产另类| 国产日韩欧美综合一区| 亚洲精品日韩一| 久久激情五月激情| jlzzjlzz亚洲女人18| 欧美精品一卡两卡| 欧美国产精品中文字幕| 天使萌一区二区三区免费观看| 菠萝蜜视频在线观看一区| 99久久精品一区二区| 欧美一区二区在线观看| 亚洲精品中文字幕乱码三区| 国产乱一区二区| 欧美日韩国产bt| 国产精品不卡一区| 裸体在线国模精品偷拍| 99久久99久久精品国产片果冻| 日韩欧美在线1卡| 亚洲精品免费在线观看| 国产一区福利在线| 6080午夜不卡| 亚洲图片欧美色图| 99久久夜色精品国产网站| 精品福利一二区| 午夜av一区二区三区| 91蜜桃网址入口| 国产精品你懂的| 国产精品中文有码| 精品国产91亚洲一区二区三区婷婷| 一区二区三区毛片| 粉嫩蜜臀av国产精品网站| 欧美va在线播放| 日本欧美在线看| 91精品国产色综合久久久蜜香臀| 亚洲精品福利视频网站| 91视频在线观看| 亚洲视频免费在线观看| 懂色av一区二区三区免费看| 久久久蜜桃精品| 国产毛片精品视频| 久久久久久9999| 国产毛片精品国产一区二区三区| 日韩精品最新网址| 免费观看成人鲁鲁鲁鲁鲁视频| 91精品在线一区二区| 婷婷一区二区三区| 欧美疯狂做受xxxx富婆| 日韩精品欧美精品| 日韩视频在线永久播放| 精品综合久久久久久8888| 日韩美女一区二区三区四区| 美女一区二区三区在线观看| 日韩午夜在线播放| 精彩视频一区二区| 久久精品人人爽人人爽| 成人激情电影免费在线观看| 国产日韩综合av| 91小视频免费观看| 亚洲午夜久久久久| 日韩一级成人av| 国产91精品在线观看| 亚洲欧洲日产国码二区| 色www精品视频在线观看| 亚洲综合图片区| 精品嫩草影院久久| 成人精品鲁一区一区二区| 一区二区三区中文在线| 欧美性色aⅴ视频一区日韩精品| 亚洲成av人片www| 欧美精品一区二区三区蜜桃| 国产不卡免费视频| 亚洲综合丁香婷婷六月香| 欧美一区二区三区思思人| 一本久道久久综合中文字幕| 亚洲男人天堂av| 91精品黄色片免费大全| 成人sese在线| 亚洲成人福利片| 国产精品全国免费观看高清| 在线这里只有精品| 国产一区免费电影| 一区二区三区中文字幕| 精品久久五月天| 91精品91久久久中77777| 日韩一区二区麻豆国产| 国产在线播精品第三| 精品少妇一区二区三区| 欧美日韩视频在线观看一区二区三区| 人禽交欧美网站| 国产日韩精品一区| 91精品黄色片免费大全| 99精品国产视频| 国模无码大尺度一区二区三区| 亚洲精品免费在线播放| 久久婷婷国产综合精品青草| 欧美日韩午夜在线视频| www.视频一区| 久草热8精品视频在线观看| 亚洲综合偷拍欧美一区色| 中文在线一区二区| 欧美va亚洲va香蕉在线| 欧美性生活影院| 色婷婷精品大视频在线蜜桃视频 | 色综合久久88色综合天天免费| 美洲天堂一区二卡三卡四卡视频 | 91精品国产91久久久久久一区二区| 成人综合婷婷国产精品久久蜜臀| 久久综合综合久久综合| 亚洲国产视频一区二区| 一区二区三区中文字幕精品精品| 久久你懂得1024| 亚洲精品在线电影| 日韩欧美中文一区| 日韩一级欧美一级| 宅男在线国产精品| 欧美久久久久久久久中文字幕| 在线看一区二区| 欧美性videosxxxxx| 日本韩国欧美在线| 欧美影片第一页| 欧美日韩免费视频| 欧美精品1区2区| 日韩一区二区中文字幕| 日韩一区二区三区四区五区六区| 91精品国产一区二区三区香蕉| 91.com视频| 精品国产一二三| 国产亚洲精品资源在线26u| 国产三级精品视频| 日韩美女啊v在线免费观看| 亚洲麻豆国产自偷在线| 亚洲成人一区二区在线观看| 日韩在线观看一区二区| 日av在线不卡| 国产美女精品人人做人人爽| 成人av电影观看| 欧美中文一区二区三区| 欧美一级一区二区| 久久免费视频一区| 亚洲欧美综合色| 亚洲美女一区二区三区| 亚洲制服欧美中文字幕中文字幕| 污片在线观看一区二区| 久久精品国产999大香线蕉| 国产精品一级黄| 色一情一乱一乱一91av| 正在播放亚洲一区| 国产亚洲精品中文字幕| 亚洲一区免费在线观看| 麻豆国产精品一区二区三区| 国产宾馆实践打屁股91| 欧美综合在线视频| 精品久久一二三区| 亚洲人成7777| 蜜臀av一区二区在线免费观看 | 欧美中文字幕一区| 精品国产亚洲在线| 亚洲欧美一区二区视频| 蜜臀av亚洲一区中文字幕| 国产成人av电影免费在线观看| 在线视频一区二区三区| 精品福利二区三区| 亚洲国产精品久久不卡毛片 | 亚洲一区二区精品3399| 国产一区二区三区电影在线观看| 91蝌蚪porny九色| 久久午夜羞羞影院免费观看| 亚洲久草在线视频| 国产成人啪免费观看软件|