HDU 2815 离散对数
来源:互联网 发布:mac怎么设置acc模式 编辑:程序博客网 时间:2024/05/17 06:20
这题就是离散对数的问题 注意N不能大于等于P就行
#include <iostream>#include<cstdio>#include<cstring>#include<cstdio>#include<cmath>using namespace std;#define maxn 65535struct hash{ int a,b,next;} Hash[maxn*2];int flg[maxn+66];int top,idx;void ins(int a,int b){ int k=b&maxn; if(flg[k]!=idx) { flg[k]=idx; Hash[k].next=-1; Hash[k].a=a; Hash[k].b=b; return; } while(Hash[k].next!=-1) { if(Hash[k].b==b) return; k=Hash[k].next; } Hash[k].next=++top; Hash[top].next=-1; Hash[top].a=a; Hash[top].b=b;}int find(int b){ int k=b&maxn; if(flg[k]!=idx) return -1; while(k!=-1) { if(Hash[k].b==b) return Hash[k].a; k=Hash[k].next; } return -1;}int gcd(int a,int b){ return b==0?a:gcd(b,a%b);}int exgcd(int a,int b,int &x,int &y){ int t,ret; if(!b) { x=1,y=0; return a; } ret=exgcd(b,a%b,x,y); t=x,x=y,y=t-a/b*y; return ret;}int inval(int a,int b,int n){ int x,y,e; exgcd(a,n,x,y); e=(long long)x*b%n; return e<0? e+n:e;}int powmod(long long a,int b,int c){ long long ret=1%c; a%=c; while(b) { if(b&1) ret=ret*a%c; a=a*a%c; b>>=1; } return ret;}int babystep(int A,int B,int C){ top=maxn; ++idx; long long buf=1%C,D=buf,K; int i,d=0,tmp; for(i=0; i<=100; buf=buf*A%C,++i) if(buf==B) return i; while((tmp=gcd(A,C))!=1) { if(B%tmp) return -1; ++d; C/=tmp; B/=tmp; D=D*A/tmp%C; } int M=(int)ceil(sqrt((double)C)); for(buf=1%C,i=0; i<=M; buf=buf*A%C,++i) ins(i,buf); for(i=0,K=powmod((long long)A,M,C); i<=M; D=D*K%C,++i) { tmp=inval((int)D,B,C); int w; if(tmp>=0&&(w=find(tmp))!=-1) return i*M+w+d; } return -1;}int main(){ int k,n,p,tmp; while(~scanf("%d%d%d",&k,&p,&n)) { if(n<0||n>=p) { printf("Orz,I can’t find D!\n"); continue; } tmp=babystep(k,n,p); if(tmp<=0) printf("Orz,I can’t find D!\n"); else printf("%d\n",tmp); } return 0;}
- HDU 2815 离散对数
- 【BSGS求离散对数】HDU Mod Tree 2815
- HDU 4887 Endless Punishment (矩阵离散对数)
- [HDU 4887 Endless Punishment] 矩阵离散对数
- HDU 2815 Mod Tree【扩展Baby Step Giant Step解决离散对数问题】
- hdu——2815(数论之Baby Step Giant Step解决离散对数问题)
- HDU 2815 Mod Tree 离散对数 扩展Baby Step Giant Step算法
- 离散对数,giant-step baby-step,拓展giant-step baby-step (poj 2417, hdu 2815)
- hdu 5377 Root 原根+离散对数+扩展欧几里得
- 【HDU】5958 New Signal Decomposition【离散对数下的FFT】
- Hdu 2815 Mod Tree + Poj 3243 Clever Y 扩展Baby Step Giant Step 解决离散对数问题
- 离散对数问题
- 离散对数加密算法
- 离散对数问题
- POJ 2417 离散对数
- 求离散对数
- 离散对数加密算法
- 离散对数求解算法
- 关于loadrunner监控windows和linux说明
- Mysql数据事务隔离级别测试
- fedora14下运行程序出现GLib- GIO:ERROR:gdbusconnection.c:2270:initable_init: assertion failed: (connection->
- 显示时钟的JavaScript源码
- 程序中调用一个可执行文件,防止小部分程序down掉导致整个程序down掉
- HDU 2815 离散对数
- 从Samples中入门IOS开发(三)------ 文档浏览
- Linux-2.6平台下SCSI子系统初始化及退出
- MFC 获得当前exe文件的路径
- python 装饰器
- c#中从string数组转换到int数组
- Tomcat 7 HTTP 连接器(一)
- UNIX Shell控制结构—IF
- 80x86寻址模式