随笔-141  评论-9  文章-3  trackbacks-0
#include <iostream>
 
using namespace std;
 
template
<int LIM,int MAX> class hp
{
    
public:
        
//vars
        int sect[MAX];
        
int scnt;
        
//constructors
        hp()
        
{
            scnt
=1;
            sect[
0]=0;
        }

        
//functions
        void copy(const hp<LIM,MAX> &A)
        
{
            
for (int i=0;i<A.scnt;i++)
                sect[i]
=A.sect[i];
            scnt
=A.scnt;
        }

        
void copy(int A)
        
{
            scnt
=0;
            
while (A)
            
{
                sect[scnt
++]=% LIM;
                A 
/=LIM;
            }

        }

        
void print()
        
{
            
int i,k;
            printf(
"%d",sect[scnt-1]);
            
for (i=scnt-2;i>=0;i--)
            
{
                k
=LIM/10;
                
while(sect[i]<k)
                
{
                    printf(
"0");
                    k
/=10;
                }

                
if (sect[i])
                    printf(
"%d",sect[i]);
            }

        }

        
void read(int LIE)
        
{
            
char A[LIM*MAX];
            
int len,i,j,k,b=0;
            scanf(
"%s",A);
            len
=strlen(A);
            k
=len % LIE;
            j
=scnt=len / LIE;
            
if (k)
            
{
                scnt
++;
                j
=scnt-1;
                sect[j]
=0;
                
for (i=0;i<k;i++)
                
{
                    sect[j]
*=10;
                    sect[j]
+=A[b++]-'0';
                }

            }

            
for (j--;j>=0;j--)
            
{
                sect[j]
=0;
                
for (i=0;i<LIE;i++)
                
{
                    sect[j]
*=10;
                    sect[j]
+=A[b++]-'0';
                }

            }

        }

        
void plus(hp<LIM,MAX> &A,int offset=0)
        
{
            
int sc=scnt > A.scnt + offset  ? scnt : A.scnt + offset;
            
int i,j,up=0;
            
for (i=0;i<sc;i++)
            
{
                j
=- offset;
                
if (j<0continue;
                
if (i>=scnt) sect[i]=0;
                
if (j>=A.scnt) A.sect[j]=0;
                sect[i]
+=A.sect[j] + up;
                up
=sect[i] / LIM;
                sect[i]
%=LIM;
            }

            scnt
=sc;
            
if (up) sect[scnt++]=up;
        }

        
void minus(hp<LIM,MAX> &A)
        
{
            
int sc=scnt;
            
int i,lend=0;
            
for (i=0;i<sc;i++)
            
{
                
if (i>=A.scnt) A.sect[i]=0;
                sect[i]
-=A.sect[i] + lend;
                lend
=0;
                
if (sect[i]<0)
                
{
                    lend
=1;
                    sect[i]
+=LIM;
                }

            }

            scnt
=sc;
            
if (lend) scnt--;
            
for (;scnt>1 && sect[scnt-1]==0;scnt--);
 
        }

        
void multiply(int p)
        
{
            
if (p==0)
            
{
                scnt
=1;
                sect[
0]=0;
                
return;
            }

            
int sc=scnt;
            
int i,up=0;
            
for (i=0;i<sc;i++)
            
{
                
if (i>=scnt) sect[i]=0;
                sect[i]
=sect[i] * p + up;
                up
=sect[i] / LIM;
                sect[i]
%=LIM;
            }

            scnt
=sc;
            
if (up) sect[scnt++]=up;
        }

        
void multiply(hp<LIM,MAX> &A)
        
{
            hp
<LIM,MAX> T,C;
            
int sc=A.scnt;
            
int i;
            
for (i=0;i<sc;i++)
            
{
                T
=(*this);
                T.multiply(A.sect[i]);
                C.plus(T,i);
            }

            scnt
=sc;
            (
*this)=C;
        }

        
int compare(hp<LIM,MAX> &A)
        
{
            
if (scnt > A.scnt)
                
return 1;
            
if (scnt < A.scnt)
                
return -1;
            
for (int i=scnt-1;i>=0;i--)
            
{
                
if (sect[i] > A.sect[i])
                    
return 1;
                
if (sect[i] < A.sect[i])
                    
return -1;
            }

            
return 0;
        }

        
//operators
        bool operator == (hp<LIM,MAX> &A)
        
{
            
int t=compare(A);
            
return t==0;
        }

        
bool operator < (hp<LIM,MAX> &A)
        
{
            
int t=compare(A);
            
return t==-1;
        }

        
bool operator > (hp<LIM,MAX> &A)
        
{
            
int t=compare(A);
            
return t==1;
        }

        
bool operator <= (hp<LIM,MAX> &A)
        
{
            
int t=compare(A);
            
return t==-1 || t==0;
        }

        
bool operator >= (hp<LIM,MAX> &A)
        
{
            
int t=compare(A);
            
return t==1 || t==0;
        }

        
void operator =(hp<LIM,MAX> A)
        
{
            copy(A);
        }

        
void operator =(int A)
        
{
            copy(A);
        }

        
void operator +=(hp<LIM,MAX> &A)
        
{
            plus(A);
        }

        
void operator -=(hp<LIM,MAX> &A)
        
{
            minus(A);
        }

        
void operator *=(hp<LIM,MAX> &A)
        
{
            multiply(A);
        }

        
void operator *=(int A)
        
{
            multiply(A);
        }

        hp
<LIM,MAX> operator +(hp<LIM,MAX> &A)
        
{
            hp
<LIM,MAX> C(*this);
            C.plus(A);
            
return C;
        }

        hp
<LIM,MAX> operator -(hp<LIM,MAX> &A)
        
{
            hp
<LIM,MAX> C(*this);
            C.minus(A);
            
return C;
        }

        hp
<LIM,MAX> operator *(int A)
        
{
            hp
<LIM,MAX> C(*this);
            C.multiply(A);
            
return C;
        }

        hp
<LIM,MAX> operator *(hp<LIM,MAX> &A)
        
{
            hp
<LIM,MAX> C(*this);
            C.multiply(A);
            
return C;
        }

}
;
posted on 2011-04-12 19:42 小阮 阅读(234) 评论(0)  编辑 收藏 引用 所属分类: 数据结构和算法

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理