gjd
#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的更多相关文章
- java web学习总结(五) -------------------servlet开发(一)
一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...
- 用bootstrap实现多张图片手动轮回
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABBoAAAJoCAIAAABHhBX4AAAgAElEQVR4nOzdZXdcV7rg8fmIM2vm3r
- C算法编程题(五)“E”的变换
前言 上一篇<C算法编程题(四)上三角> 插几句话,说说最近自己的状态,人家都说程序员经常失眠什么的,但是这几个月来,我从没有失眠过,当然是过了分手那段时期.每天的工作很忙,一个任务接一个 ...
- 自己使用的一个.NET轻量开发结构
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIgAAABFCAIAAAAerjlvAAAE2UlEQVR4nO2a3U/bVhiH+bdyPaqpmx
- 15、ASP.NET MVC入门到精通——MVC-路由
本系列目录:ASP.NET MVC4入门到精通系列目录汇总 Routing(路由) – URL url 作为广泛使用的Web用户接口,需要被重视 好的Url应该满足如下条件: URL应为获取某种资源提 ...
- javaweb学习总结(五)——Servlet开发(一)
一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...
- Java基础语法
java基础学习总结——基础语法1 一.标识符
- python之路2(基础详解)
python一切都是对象: 列子:
- 数据处理之CoreData
一.CoreData数据库框架与Sqlite对比 Sqlite: 1.基于C接口, 需要使用sql语句, 代码繁琐 2.在处理大量数据时, 表关系更直观 3.在OC中不是可视化的 CoreData: ...
随机推荐
- 后台程序员的HTTP缓存
1.后端程序员只需要关注请求头: if-None-Match //上一次response头中的ETag的值. 响应头: Etag //是URL的Entity Tag,用于标示URL对象是否改变,区分不 ...
- Shared Library Search Paths
在使用CodeLite编译动态库的时候,可以通过在Linker > Linker Options中添加: -install_name @executable_path/libXXX.so 的方式 ...
- 如何让Chrome浏览器可以加载本地XML文件?
Chrome浏览器的安全限制,禁止本地加载XML等外部文件,如何设置让其可以加载呢? 有两种方法,第一种是在本地服务器环境下浏览,采用 http://localhost/ 的方式浏览你的网页和文件,就 ...
- fork与vfork
先看一个fork的例子: ; int main(void) { int var, pid; ; ) { printf("vfork error"); exit(-); } ) { ...
- WebGrid Helper with Check All Checkboxes
WebGrid Helper with Check All Checkboxes myEvernote Link Tuesday, September 13, 2011ASP.NET ASP.NET ...
- Linux环境PHP5.5以上连接SqlServer2008【全网最经典无错版】
原文地址:http://blog.csdn.net/21aspnet/article/details/47451253 linux版本:64位CentOS 6.4 Nginx版本:nginx1.8.0 ...
- vtk第一个程序
首先 设置环境变量 解决方案资源管理器 选中项目名字 而不是ALL_BUILD 选项卡 项目-属性 右侧 附加依赖项->编辑 kernel32.libuser32.libgdi32.libwin ...
- 修改PUTTY支持保存密码
1.从官网下载 Putty 0.60 Release 的 Windows 版源码 http://www.chiark.greenend.org.uk/~sgtatham/putty/download. ...
- HTML5 之Canvas绘制太阳系
<!DOCTYPE html> <html> <head> <title>HTML5_Canvas_SolarSystem</title> ...
- 分解大质数模板(复杂度小于sqrt(n))
//POJ 1811 #include <cstdio> #include <cstring> #include <algorithm> #include < ...