【codevs 1565】【SDOI 2011】计算器 快速幂+拓展欧几里得+BSGS算法
BSGS算法是meet in the middle思想的一种应用,参考Yveh的博客我学会了BSGS的模版和hash表模板,,,
现在才会hash是不是太弱了,,,
#include<cmath>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct node{
static const int mo=100007;
int a[100010],v[100010];
node() {memset(a,-1,sizeof(a));}
int find(int val){
int pos=(val%mo+mo)%mo;
while ((a[pos]!=val)&&(a[pos]!=-1)) pos=(pos+1)%mo;
return pos;
}
void insert(int val,int x){
int pos=find(val);
if ((a[pos]==-1)||(a[pos]==val)){
a[pos]=val;
v[pos]=x;
}
}
int get(int val){
int pos=find(val);
return a[pos]==val?v[pos]:-1;
}
void clear() {memset(a,-1,sizeof(a));}
}hash;
int T,L;
inline int work1(int a,int b,int n){
long long t=a,ans=1;
while (b){
if (b%2==1) ans=(ans*t)%n;
b=b/2;
t=(t*t)%n;
}
return (int)ans;
}
inline int exgcd(int a,int b,int &x,int &y){
if (b==0){
x=1; y=0; return a;
}else{
int r=exgcd(b,a%b,x,y);
int t=y;
y=x-a/b*y;
x=t;
return r;
}
}
inline void work2(int a,int b,int n){
int x,y;
int d=exgcd(a,n,x,y);
if (b%d) puts("Orz, I cannot find x!\n");
else printf("%d\n",(int)((((long long)x*b/d%n)+n)%n));
}
inline void work3(int a,int b,int n){
if ((a%n==0)&&(b!=0)) {puts("Orz, I cannot find x!\n"); return;}
hash.clear();
int m=ceil(sqrt(n));
long long t=b%n;
for(int i=0;i<=m;++i){
hash.insert((int)t,i);
t=(t*a)%n;
}
int s=work1(a,m,n); t=s;
for(int i=1;i<=m;++i){
int v=hash.get((int)t);
if (v!=-1) {printf("%d\n",i*m-v); return;}
t=(t*s)%n;
}
puts("Orz, I cannot find x!\n");
}
int main(){
scanf("%d %d\n",&T,&L);
int y,z,p,a,b;
switch (L){
case 1:
while (T--){
scanf("%d %d %d\n",&y,&z,&p);
printf("%d\n",work1(y,z,p));
}
break;
case 2:
while (T--){
scanf("%d %d %d\n",&y,&z,&p);
work2(y,z,p);
}
break;
case 3:
while (T--){
scanf("%d %d %d\n",&y,&z,&p);
work3(y,z,p);
}
break;
}
return 0;
}
这样就可以啦
【codevs 1565】【SDOI 2011】计算器 快速幂+拓展欧几里得+BSGS算法的更多相关文章
- BZOJ-2242 计算器 快速幂+拓展欧几里得+BSGS(数论三合一)
污污污污 2242: [SDOI2011]计算器 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 2312 Solved: 917 [Submit][S ...
- bzoj 2242 [SDOI2011]计算器 快速幂+扩展欧几里得+BSGS
1:快速幂 2:exgcd 3:exbsgs,题里说是素数,但我打的普通bsgs就wa,exbsgs就A了...... (map就是慢)..... #include<cstdio> # ...
- 【bzoj2242】: [SDOI2011]计算器 数论-快速幂-扩展欧几里得-BSGS
[bzoj2242]: [SDOI2011]计算器 1.快速幂 2.扩展欧几里得(费马小定理) 3.BSGS /* http://www.cnblogs.com/karl07/ */ #include ...
- 【bzoj1965】: [Ahoi2005]SHUFFLE 洗牌 数论-快速幂-扩展欧几里得
[bzoj1965]: [Ahoi2005]SHUFFLE 洗牌 观察发现第x张牌 当x<=n/2 x=2x 当x>n/2 x=2x-n-1 好像就是 x=2x mod (n+1) 就好 ...
- poj 1845 【数论:逆元,二分(乘法),拓展欧几里得,费马小定理】
POJ 1845 题意不说了,网上一大堆.此题做了一天,必须要整理一下了. 刚开始用费马小定理做,WA.(poj敢说我代码WA???)(以下代码其实都不严谨,按照数据要求A是可以等于0的,那么结果自然 ...
- Looooops(求解同余方程、同余方程用法)【拓展欧几里得】
Looooops(点击) A Compiler Mystery: We are given a C-language style for loop of type for (variable = A; ...
- [zoj 3774]Power of Fibonacci 数论(二次剩余 拓展欧几里得 等比数列求和)
Power of Fibonacci Time Limit: 5 Seconds Memory Limit: 65536 KB In mathematics, Fibonacci numbe ...
- Codeforces 898 B(拓展欧几里得)
Proper Nutrition 题意:有n元钱,有2种单价不同的商品,是否存在一种购买方式使得钱恰好花光,如果有输入任意一种方式,如果没有输出“NO” 题解:可以使用拓展欧几里得快速求解. #inc ...
- NOIP2012拓展欧几里得
拉板题,,,不说话 我之前是不是说过数据结构很烦,,,我想收回,,,今天开始的数论还要恶心,一早上听得头都晕了 先来一发欧几里得拓展裸 #include <cstdio> void gcd ...
随机推荐
- 阿里云+wordpress搭建个人博客网站【小白专用的图文教程】
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 2016.11.17 NOI plus day0
今天很乱乱乱乱 根本不想写代码 玩了一早上了 昨晚失眠了 今天又懵逼了 中午就要走了 明天就要考试了 考完试回来就要补文化课了 现在我的内心很平静 因为已经紧张的冻结了 你知道什么叫彷徨么? 机房里的 ...
- HQL基础查询语句
HQL基础查询语句 1.使用hql语句检索出Student表中的所有列 //核心代码 @Test public void oneTest() { Query query=session.createQ ...
- string、math类、random随机数、datetime、异常保护
今天讲的知识点比较多,比较杂,以至于现在脑子里还有点乱,慢慢来吧... string (1)string.length; (获得你string字符串的长度) (2)a = a.Trim(); 重新赋值 ...
- java 25 - 3 网络编程之 Socket套接字
Socket Socket套接字: 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字. Socket原理机制: 通信的两端都有Socket. 网络通信其实就是Socket ...
- net对XML增删改查
Pass:看公司代码,配置下拉框的功能,和下拉框的数字转文字.配置xml里面有下拉的value,name,这样界面直接显示数字,然后转译成中文 1.xml文件格式 <?xml version=& ...
- Javascript备忘复习笔记2
一.函数与形参 1.函数 function abs(x) { if (x >= 0) { return x; } else { return -x; } } alert(abs(-10)); 2 ...
- IE8 HACK介绍
1.‘\9’: eg:.test { color/*\**/: blue\9 }.header {width:300px;} /* 所有浏览器*/.header {width/*\**/:330px\ ...
- cpu负载和利用率
理解Linux系统负荷 linux里的CPU负载
- android错误之MediaPlayer用法的Media Player called in state *,androidmediaplayer
用到Media Player,遇到几个问题,记一下 用法就不说了,使用的时候最好参考一下mediaPlayer的这张图 第一个错误是Media Player called in state 8 这个是 ...