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

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

?? ps_zzn.cpp

?? 比較新的功能強大的rsa算法源代碼,方便使用.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * C++ class to implement a power series type and to allow 
 * arithmetic on it
 *
 * WARNING: This class has been cobbled together for a specific use with
 * the MIRACL library It is not complete, and may not work in other 
 * applications
 *
 * See Knuth The Art of Computer Programming Vol.2, Chapter 4.7 
 */

#include "ps_zzn.h"

#define FFT

//
// all calulations are mod x^psN
// Power series is stored {as offset, pwr and a0+a1.x+a2.x^2+a3.x^3....}
// where the power of x is to be multiplied by pwr, and the whole power
// series is to be divided by x^offset
//

int psN;

//
// Copy Constructor
//

Ps_ZZn::Ps_ZZn(const Ps_ZZn& p)
{
    term_ps_zzn *ptr=p.start;
    term_ps_zzn *pos=NULL; 
    int pw;
    start=NULL;
    offset=p.offset;
    pwr=p.pwr;
    while (ptr!=NULL)
    {
        pw=ptr->n*p.pwr-p.offset;   // conversion needed
        if (pw>=psN) break;
        pos=addterm(ptr->an,pw,pos);
        ptr=ptr->next;
    }
}

//
// decompresses PS by reducing pwr
//

void Ps_ZZn::decompress(int m)
{ // m is divisor of current pwr
  // e.g pwr is 6 and PS = 1 + x + x^2
  // If m=2 then pwr becomes 3 and PS = 1 +x^2 +x^4.... 
    term_ps_zzn *ptr=start;
    if (start==NULL || m==1 || pwr==1) return; // it is fully decompressed
    while (ptr!=NULL)
    {
        ptr->n*=m;
        ptr=ptr->next;
    }
    pwr/=m;
}

//
//  Sets new pwr value. Parameter must exactly divide 
//  all powers in the series
//

void Ps_ZZn::compress(int p)
{
    term_ps_zzn *ptr=start;
    if (p==1) return;
    while (ptr!=NULL)
    {
        ptr->n/=p;
        ptr=ptr->next;  
    }
    pwr=p;
}

//
// insert missing terms with 0 coefficients
//

void Ps_ZZn::pad()
{ // insert any missing 0 coefficients 
    int i=0;
    term_ps_zzn *ptr=start;
    term_ps_zzn *pos=NULL;
    while (ptr!=NULL)
    {
        while (i<ptr->n)
        {
            pos=addterm((ZZn)0,i*pwr-offset,pos);
            i++;
        }
        i++;
        ptr=ptr->next;
    }
    while (i<psN/pwr) 
    {
        pos=addterm((ZZn)0,i*pwr-offset,pos);
        i++;
    }
}

//
// Find max coefficient in PS
//

int Ps_ZZn::max()
{
    int b,m=0;
    term_ps_zzn *ptr=start;
    while (ptr!=NULL)
    {
        b=bits((Big)ptr->an);
        if (b>m) m=b;
        ptr=ptr->next;
    }
    return m;
}

//
// set new offset, so first power of x is 0
//

void Ps_ZZn::norm()
{
    int m;
    term_ps_zzn *ptr;
    if (start==NULL) return;
//
// remove any leading 0 terms
//
    while (start->an.iszero()) 
    {
        ptr=start->next;
        delete start;
        start=ptr;
        if (start==NULL) return;
    }
    ptr=start;
    m=start->n;
    if (m!=0)
    {
        offset-=m*pwr;
        while (ptr!=NULL)
        {
            ptr->n-=m;
            ptr=ptr->next;
        }
    }
}

//
// Dedekind Eta function (1-x)(1-x^2)(1-x^3)....
//

Ps_ZZn eta()
{ // simple repeating pattern
    BOOL even;
    int one,ce,co,c;
    term_ps_zzn *pos=NULL;
    Ps_ZZn n;
    n.addterm((ZZn)1,0);
    n.addterm((ZZn)-1,1);
    n.addterm((ZZn)-1,2); 
    ce=2;co=1;
    even=TRUE;
    c=2;
    one=1;
    while (c<psN)
    {
        if (even)
        {
            c+=(ce+1);
            ce+=2;
            pos=n.addterm((ZZn)one,c,pos);
            even=FALSE;
        }
        else
        {
            c+=(co+1);
            co+=1;
            pos=n.addterm((ZZn)one,c,pos);
            even=TRUE;
            one=(-one);
        }
    }
    return n;
}

//
// Checks if a power series is 0 or an integer
//

BOOL Ps_ZZn::IsInt() const
{
    if (start==NULL) return TRUE;
    if (one_term() && offset==0) return TRUE;
    return FALSE;
}

//
// return TRUE if zero or one term only in PS
//

BOOL Ps_ZZn::one_term() const
{
    int t=0;
    term_ps_zzn *ptr=start;
    if (start==NULL) return TRUE;
    while (ptr!=NULL)
    {
        if (!ptr->an.iszero()) t++;
        if (t>1) return FALSE;
        ptr=ptr->next;
    }
    return TRUE;
}

//
// add a term to a PS
//

term_ps_zzn* Ps_ZZn::addterm(const ZZn& a,int power,term_ps_zzn* pos)
{
    term_ps_zzn* newone;  
    term_ps_zzn* ptr;
    term_ps_zzn *t,*iptr;
    int dc,pw;
    ptr=start;
    iptr=NULL;

//
// intelligently determine the most compressed form to use
// for example if coefficient a=1 always, and power = -7 -5 -3 -1 1 3....
// then set pwr=2, offset=7  and PS = 1 + x + x^2
//
    pw=power+offset;
    if (one_term() && pw!=0)
    { // when PS has only one term, pwr is undefined
        if (pw<0)
            pwr=-pw;
        else pwr=pw; 
    }   

    dc=igcd(pw,pwr);

    if (dc != pwr) decompress(pwr/dc);
    power=pw/pwr;
// quick scan through to detect if term exists already
// and to find insertion point
   if (pos!=NULL) ptr=pos;
    while (ptr!=NULL) 
    { 
        if (ptr->n==power)
        {
            ptr->an+=a;

            if (ptr->an.iszero()) 
            { // delete term
                if (ptr==start)
                { // delete first one
                    start=ptr->next;
                    delete ptr;
                    norm();
                    return start;
                }
                iptr=ptr;
                ptr=start;
                while (ptr->next!=iptr)ptr=ptr->next;
                ptr->next=iptr->next;
                delete iptr;
                return ptr;
            }
            return ptr;
        }
        if (ptr->n<power) iptr=ptr;   // determines order
        else break;
        ptr=ptr->next;
    }
    newone=new term_ps_zzn;
    newone->next=NULL;
    newone->an=a;
    newone->n=power;
    pos=newone;
    if (start==NULL)
    {
        start=newone;
        norm();
        return pos;
    }

// insert at the start

    if (iptr==NULL)
    { 
        t=start;
        start=newone;
        newone->next=t;
        norm();
        return pos;
    }

// insert new term

    t=iptr->next;
    iptr->next=newone;
    newone->next=t;
    return pos;    
}

//
// Destructor
//

Ps_ZZn::~Ps_ZZn()
{
    term_ps_zzn *nx;
    while (start!=NULL)
    {
        nx=start->next;
        delete start;
        start=nx;
    }
}

//
// get coefficient of actual power
//

ZZn Ps_ZZn::coeff(int power) const
{
    ZZn c=0;
    term_ps_zzn *ptr=start;
    if ((power+offset)%pwr != 0) return c;  // no such term
    power=(power+offset)/pwr;

    while (ptr!=NULL)
    {
        if (ptr->n==power)
        {
            c=ptr->an;
            return c;
        }
        ptr=ptr->next;
    }
    return c;
}

//
// get coefficient of "Internal" power
//

ZZn Ps_ZZn::cf(int power) const
{
    ZZn c=0;
    term_ps_zzn *ptr=start;

    while (ptr!=NULL)
    {
        if (ptr->n==power)
        {
            c=ptr->an;
            return c;
        }
        ptr=ptr->next;
    }
    return c;
}

//
// Zeroise PS and reclaim space
//

void Ps_ZZn::clear()
{
    term_ps_zzn *ptr;
    while (start!=NULL)
    {
        ptr=start->next;
        delete start;
        start=ptr;
    }
    offset=0;
    pwr=1;
}

// Note: real power = internal power * pwr - offset 

Ps_ZZn& Ps_ZZn::operator+=(const Ps_ZZn& p)
{
    term_ps_zzn *ptr=p.start;
    term_ps_zzn *pos=NULL;
    int pw;   
    while (ptr!=NULL)
    {
        pw=ptr->n*p.pwr-p.offset;   // convert compressed to real
        if (pw>=psN) break;
        pos=addterm(ptr->an,pw,pos);
        ptr=ptr->next;
    }
    return *this;
}

Ps_ZZn operator-(const Ps_ZZn& p)
{
    Ps_ZZn r=p;
    term_ps_zzn *ptr=r.start;
    while (ptr!=NULL)
    {
        ptr->an=(-ptr->an);
        ptr=ptr->next;
    }
    return r;
}

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

    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;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产色一区| 粉嫩av亚洲一区二区图片| 国产激情一区二区三区| 在线观看亚洲精品| 久久精品男人天堂av| 日韩高清中文字幕一区| 91麻豆精品在线观看| 久久精品人人做人人爽97| 日韩电影在线观看一区| 91首页免费视频| 欧美国产激情二区三区 | 久久精品视频在线免费观看| 亚洲图片有声小说| 成人黄色国产精品网站大全在线免费观看| 91精品国产综合久久久久久久 | 99精品久久免费看蜜臀剧情介绍| 精品福利一区二区三区| 日精品一区二区| 欧美亚洲免费在线一区| 亚洲欧美一区二区三区久本道91 | 国产精品二三区| 国产精品91xxx| 久久久久9999亚洲精品| 六月婷婷色综合| 欧美一级欧美三级在线观看| 午夜久久久久久电影| 91久久国产最好的精华液| 最新日韩在线视频| 99视频有精品| 亚洲色图丝袜美腿| 99国产精品视频免费观看| 国产精品久线在线观看| 99视频热这里只有精品免费| 综合激情成人伊人| 97久久精品人人爽人人爽蜜臀| 国产精品视频在线看| av男人天堂一区| 中文字幕日韩一区| 日本高清免费不卡视频| 亚洲综合激情另类小说区| 欧亚洲嫩模精品一区三区| 日韩va欧美va亚洲va久久| 日韩视频在线你懂得| 黄色日韩网站视频| 国产精品三级av在线播放| 99热在这里有精品免费| 亚洲制服丝袜av| 欧美一区二区三级| 国产精品小仙女| 亚洲欧洲制服丝袜| 在线播放欧美女士性生活| 国产真实乱偷精品视频免| 国产精品嫩草影院com| 欧洲亚洲精品在线| 日韩av午夜在线观看| 国产拍揄自揄精品视频麻豆| 一本一道综合狠狠老| 日韩av电影一区| 欧美激情一区二区在线| 91国产免费看| 国产资源在线一区| 亚洲精品欧美专区| 日韩视频免费观看高清在线视频| 成人一区二区三区中文字幕| 亚洲资源在线观看| 久久久91精品国产一区二区三区| 91丨porny丨在线| 精品一区二区三区在线视频| 中文字幕在线不卡| 欧美一区欧美二区| 99国产精品久久| 蜜臀精品久久久久久蜜臀| 中文字幕一区二区视频| 日韩欧美一级特黄在线播放| 不卡一区二区在线| 麻豆免费精品视频| 一区二区视频在线看| 久久欧美中文字幕| 欧美日本一区二区| 成人国产在线观看| 久久99精品国产麻豆婷婷洗澡| 一区二区三区在线视频免费| 欧美经典三级视频一区二区三区| 3atv在线一区二区三区| 99久久国产综合精品麻豆| 激情综合色综合久久综合| 亚洲国产裸拍裸体视频在线观看乱了| 国产日本欧洲亚洲| 精品久久久久久久久久久院品网| 在线视频你懂得一区二区三区| 国产乱码精品一区二区三区忘忧草| 五月天精品一区二区三区| 亚洲欧洲中文日韩久久av乱码| 欧美国产国产综合| 久久久久久久综合日本| 日韩午夜中文字幕| 欧美精品久久一区二区三区 | 狠狠色丁香婷婷综合| 图片区小说区国产精品视频| 亚洲欧美国产77777| 欧美国产成人在线| 久久影院电视剧免费观看| 日韩欧美一区中文| 制服.丝袜.亚洲.另类.中文| 欧美日韩卡一卡二| 欧美综合天天夜夜久久| 99久久亚洲一区二区三区青草| 成人做爰69片免费看网站| 东方aⅴ免费观看久久av| 国产精品888| 国产成人午夜视频| 国产成人啪免费观看软件| 国产大陆a不卡| 豆国产96在线|亚洲| av中文字幕亚洲| 99re在线视频这里只有精品| 成人av片在线观看| a美女胸又www黄视频久久| 91丨porny丨蝌蚪视频| 日本韩国一区二区三区视频| 欧美性做爰猛烈叫床潮| 欧美精品自拍偷拍动漫精品| 欧美一区二区三区色| 精品国产欧美一区二区| 久久综合色播五月| 国产精品国产成人国产三级| 亚洲手机成人高清视频| 亚洲国产精品久久不卡毛片| 日韩激情视频在线观看| 久久国产三级精品| 国产xxx精品视频大全| 99久久精品国产麻豆演员表| 欧洲色大大久久| 日韩无一区二区| 国产精品女同一区二区三区| 亚洲制服丝袜av| 免费成人av在线| 成人午夜激情影院| 在线看国产日韩| 精品成人在线观看| 国产精品二区一区二区aⅴ污介绍| 亚洲影视在线观看| 久久99精品国产91久久来源| 成人黄色电影在线| 8x8x8国产精品| 中文字幕成人网| 亚洲va欧美va人人爽午夜| 国产一区二区三区四区五区美女| 成人黄色在线网站| 欧美疯狂性受xxxxx喷水图片| 国产午夜精品一区二区三区视频 | 在线亚洲+欧美+日本专区| 欧美一级电影网站| 国产精品久久久久精k8| 午夜精品影院在线观看| 丁香六月综合激情| 欧美另类变人与禽xxxxx| 亚洲国产成人午夜在线一区| 亚洲国产精品自拍| 国产成人精品三级| 欧美年轻男男videosbes| 国产精品伦理在线| 久久69国产一区二区蜜臀| 91尤物视频在线观看| 337p日本欧洲亚洲大胆精品| 亚洲国产欧美在线人成| jiyouzz国产精品久久| 日韩欧美不卡在线观看视频| 亚洲一区二区视频在线| 国产99久久精品| 欧美videossexotv100| 六月丁香综合在线视频| 色婷婷国产精品| 国产欧美日韩不卡| 另类中文字幕网| 91精品国产一区二区三区香蕉| 一区二区三区在线免费播放| 国产成人精品www牛牛影视| 91精品在线免费观看| 亚洲一区自拍偷拍| 97精品视频在线观看自产线路二| 国产日产精品1区| 国产乱码精品一区二区三| 日韩精品一区二区三区老鸭窝| 亚洲成人激情av| 欧美色涩在线第一页| 亚洲视频网在线直播| 91视频免费看| 中文字幕亚洲成人| kk眼镜猥琐国模调教系列一区二区| 欧美激情一二三区| 高清国产一区二区三区| 久久久精品综合| 国产成人自拍高清视频在线免费播放| 久久众筹精品私拍模特| 国产在线不卡视频| 久久久综合视频| 国产一区二区三区在线观看精品| 久久久亚洲精华液精华液精华液 | 国产成人在线观看|