#include <cstdio>
#include <cstring>
#include <malloc.h>
#define radix (1u<<28)
#define drdx (radix-1)
#define max_size 100000000u
typedef unsigned int qt;
typedef qt ul;
inline qt max(qt a,qt b){ return ((-((a-b)>>31))&(b-a))+a; }
inline qt min(qt a,qt b){ return ((-((a-b)>>31))&(a-b))+b; }
struct bigint{
qt *d;
qt s,l;
};
template<class T> inline void alc ( T* &p, ul l ){
p=(T*)malloc( l * sizeof(T) );
}
template<class T> inline void palc( T* f, T* &t, ul l, ul a ){
if(t) free(t),t=NULL;
alc( t, a );
memcpy( t, f, sizeof(T) * l );
memset( t+l, 0, sizeof(T) * (a-l) );
}
template<class T> inline void palc( T* &t, ul a ){
if(t) free(t),t=NULL;
alc( t, a );
memset( t, 0, sizeof(T) * a );
}
inline void larger(bigint& i){
qt *p=NULL;
palc(i.d,p,i.l,i.s<<1);
i.s<<=1;
free(i.d);
i.d=p;
}
inline qt add(bigint& a,bigint& b){//return carry
qt l=max(a.l,b.l),car=0;
while(a.s<l) larger(a);
a.l=l; qt i=0;
for(;i<l;++i){
if(b.l==i) break;
a.d[i]+=b.d[i]+car;
car=a.d[i]>>28;
a.d[i]&=drdx;
}
for(;i<l;++i){
a.d[i]+=car;
car=a.d[i]>>28;
a.d[i]&=drdx;
}
return car;
}
inline qt sub(bigint& a,bigint& b){//return borrow
qt l=max(a.l,b.l),bor=0;
while(a.s<l) larger(a);
a.l=l; qt i=0;
for(;i<l;++i){
if(b.l==i) break;
a.d[i]-=b.d[i]+bor;
bor=a.d[i]>>31;
a.d[i]+=(-bor)&radix;
}
for(;i<l;++i){
a.d[i]-=bor;
bor=a.d[i]>>31;
a.d[i]+=(-bor)&radix;
}
if(!bor){
while(!a.d[--a.l]);
++a.l;
}
return bor;
}
inline qt mul_basecase(bigint& c,bigint& a,bigint& b){//return carry, c=c+a*b
qt l=a.l+b.l,car=0;
while(c.s<l) larger(c);
for(qt i=0;i<a.l;++i) for(qt j=0,p=i;j<b.l;++j,++p) {
long long nk=(long long)a.d[i]*b.d[j]+c.d[p];
c.d[p]=nk&drdx;
c.d[p+1]+=nk>>28;
c.d[p+2]+=c.d[p+1]>>28;
c.d[p+1]&=drdx;
}
if(c.d[l-1]) c.l=l; else c.l=l-1;
return c.d[l-1]>>28;
}
inline qt mul_limb(bigint& a,qt limb){
qt car=0;
for(int i=0;i<a.l;++i){
long long nk=(long long)a.d[i]*limb+car;
a.d[i]=nk&drdx;
car=nk>>28;
}
return car;
}
inline qt sqr_basecase(bigint& c,bigint& a){//a speed-up of roughly a half
qt l=a.l+a.l,car=0;
while(c.s<l) larger(c);
for(qt i=0;i<a.l;++i){
qt p=i<<1;
long long nk=(long long)a.d[i]*a.d[i]+c.d[p];
c.d[p]=nk&drdx;
c.d[p+1]+=nk>>28;
c.d[p+2]+=c.d[p+1]>>28;
c.d[p+1]&=drdx;
++p;
for(qt j=i+1;j<a.l;++j,++p) {
long long nk=((long long)a.d[i]*(a.d[j])<<1)+c.d[p];
c.d[p]=nk&drdx;
c.d[p+1]+=nk>>28;
c.d[p+2]+=c.d[p+1]>>28;
c.d[p+1]&=drdx;
}
}
if(c.d[l-1]) c.l=l; else c.l=l-1;
return c.d[l-1]>>28;
}
inline qt mul(bigint& c,bigint& a,bigint& b); //automatically select the algorithm used
inline qt sqr(bigint& c,bigint& a);
inline qt div(bigint& a,bigint& b,bigint& r);
inline bigint empty(qt ofsize){
bigint vt;
vt.l=1; vt.s=ofsize;
vt.d=NULL;
palc(vt.d,vt.s);
return vt;
}
inline bigint copy(bigint p){//obtaining a copy from p
bigint vt=p;
qt* t;
palc(vt.d,t,vt.l,vt.s);
vt.d=t;
return vt;
}
inline void pushCarry(bigint& p,qt car){
if(p.l==p.s) larger(p);
p.d[p.l++]=car;
}
inline void getBigInt_tm1(bigint& p){
scanf("%u",&p.l);
while(p.s<p.l) larger(p);
for(qt i=0;i<p.l;++i) scanf("%u",&p.d[i]);
}
inline void printBigInt_tm1(bigint& p){
printf("Length of BigInt: %u\n Size of BigInt: %u int(s)\n",p.l,p.s);
printf(" %-10d * 2^%-4d",p.d[0],0);
for(qt i=1,v=28;i<p.l;(++i)&3?0:putchar('\n'),v+=28) printf(" + %-10d * 2^%-4d",p.d[i],v);
putchar('\n');
}
inline void makeEmpty(bigint& n){
memset(n.d,0,sizeof(qt)*n.l);
n.l=1;
}
inline void makeIdentity(bigint& n){
memset(n.d,0,sizeof(qt)*n.l);
n.d[0]=1;
n.l=1;
}
inline void transfer(bigint& dest,bigint& src){
while(dest.s<src.l) larger(dest);
memcpy(dest.d,src.d,sizeof(qt)*src.l);
dest.l=src.l;
}
//fast powering error code: -1: result too large
inline int fastPower(bigint& n,qt now){
qt size=n.l*now;
if(size>max_size) return -1;
bigint cs[2],cx;
qt fx=0;
cs[0]=empty(size),cs[1]=empty(size),cx=empty(size);
transfer(cs[0],n);
for(;now;(now>>=1),fx=1-fx){
makeEmpty(cx);
if(now&1){
mul(cx,cs[fx],n);
transfer(n,cx);
}
makeEmpty(cs[1-fx]);
sqr(cs[1-fx],cs[fx]);
}
return 0;
}
inline qt karatsuba_mul(bigint& c,bigint& a,bigint& b);
inline qt toom_3_mul(bigint& c,bigint& a,bigint& b);
inline qt toom_4_mul(bigint& c,bigint& a,bigint& b);
inline qt ss_mul(bigint& c,bigint& a,bigint& b); ////////////Classical part ends.

gjd的更多相关文章

  1. java web学习总结(五) -------------------servlet开发(一)

    一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...

  2. 用bootstrap实现多张图片手动轮回

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABBoAAAJoCAIAAABHhBX4AAAgAElEQVR4nOzdZXdcV7rg8fmIM2vm3r

  3. C算法编程题(五)“E”的变换

    前言 上一篇<C算法编程题(四)上三角> 插几句话,说说最近自己的状态,人家都说程序员经常失眠什么的,但是这几个月来,我从没有失眠过,当然是过了分手那段时期.每天的工作很忙,一个任务接一个 ...

  4. 自己使用的一个.NET轻量开发结构

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIgAAABFCAIAAAAerjlvAAAE2UlEQVR4nO2a3U/bVhiH+bdyPaqpmx

  5. 15、ASP.NET MVC入门到精通——MVC-路由

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 Routing(路由) – URL url 作为广泛使用的Web用户接口,需要被重视 好的Url应该满足如下条件: URL应为获取某种资源提 ...

  6. javaweb学习总结(五)——Servlet开发(一)

    一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...

  7. Java基础语法

    java基础学习总结——基础语法1 一.标识符

  8. python之路2(基础详解)

    python一切都是对象: 列子:

  9. 数据处理之CoreData

    一.CoreData数据库框架与Sqlite对比 Sqlite: 1.基于C接口, 需要使用sql语句, 代码繁琐 2.在处理大量数据时, 表关系更直观 3.在OC中不是可视化的 CoreData: ...

随机推荐

  1. Red Black Tree in C

    http://web.mit.edu/~emin/www.old/source_code/red_black_tree/index.html

  2. ssh远程连接ubuntu

    1. 首先在服务器上安装ssh的服务器端. $ sudo aptitude install openssh-server 2. 启动ssh-server. $  sudo /etc/init.d/ss ...

  3. python中os/sys/platform模块区别

    os:This module provides a portable way of using operating system dependent functionality. sys:This m ...

  4. 使用hessian开发WebService,轻量级,更简单、快捷

    Hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能. 相比WebService,Hessian更简单.快捷.采用的是二进制RPC协议,因为采用的是二进制协 ...

  5. CF456D A Lot of Games (字典树+DP)

    D - A Lot of Games CF#260 Div2 D题 CF#260 Div1 B题 Codeforces Round #260 CF455B D. A Lot of Games time ...

  6. jquery eval解析JSON中的注意点介绍

    在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式:使用eval()函数.使用Function对象来进行返回解析,下面有个示例,感兴趣的朋友可以参考下   在JS中将JSON的字符串解析 ...

  7. css3 实现逐帧动画

    css3 实现逐帧动画 实现逐帧动画需要使用到的是Animation动画,该CSS3的Animation有八个属性:分别是如下:1: animation-name2: animation-durati ...

  8. 【UEditor】 UEditor整合项目上传资源到阿里云服务器

    目录 关于此文 下载源码 JSP代码 Java代码 阿里云jar包引入配置 成功啦! 回到顶部 关于此文 项目中要实现编辑器生成带格式的html文档,存入模板,最后生成html的URL,所以选择了UE ...

  9. Android应用如何监听自己是否被卸载及卸载反馈功能的实现

    一个应用被用户卸载肯定是有理由的,而开发者却未必能得知这一重要的理由,毕竟用户很少会主动反馈建议,多半就是用得不爽就卸,如果能在被卸载后获取到用户的一些反馈,那对开发者进一步改进应用是非常有利的.目前 ...

  10. PHP基础之 string 字符串函数

    /*=================常用字符串处理函数================== ltrim();        //去掉字符串左边的空格 rtrim();         //去掉字符串 ...