日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P3306-[SDOI2013]随机数生成器【BSGS】

發布時間:2023/12/3 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P3306-[SDOI2013]随机数生成器【BSGS】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

正題

題目鏈接:https://www.luogu.com.cn/problem/P3306


題目大意

給出一個p,a,b,x1,tp,a,b,x_1,tp,a,b,x1?,t,有xi=axi?1+bx_i=ax_{i-1}+bxi?=axi?1?+b
求一個最小的nnn使得xn=tx_n=txn?=t


解題思路

下標縮一下先變成x0x_0x0?會更好算一點,只考慮x0x_0x0?的貢獻就是x0×anx_0\times a^nx0?×an,這個比較好搞。

bbb的貢獻的話,對于第iii次加入的bbb貢獻是an?ia^{n-i}an?i總共也就是b×∑i=0n?1aib\times \sum_{i=0}^{n-1}a^ib×i=0n?1?ai
通項公式一下合起來就是
x0an+an?1a?1b=tx_0a^n+\frac{a^n-1}{a-1}b=tx0?an+a?1an?1?b=t
ana^nan提到前面來就是
an=t(a?1)+bxa?x+ba^n=\frac{t(a-1)+b}{xa-x+b}an=xa?x+bt(a?1)+b?
后面那個是已知的,然后就是上BSGS\text{BSGS}BSGS就好了。

需要注意的是如果a=1a=1a=1就不能用通項公式了,得上exgcd\text{exgcd}exgcd來搞。

要特判的東西有點多就不多講了


code

#include<cstdio> #include<cstring> #include<algorithm> #include<map> #include<cmath> #define ll long long using namespace std; ll T,p,a,b,x,t,ans; map<ll,ll> v; ll power(ll x,ll b){ll ans=1;while(b){if(b&1)ans=ans*x%p;x=x*x%p;b>>=1;}return ans; } ll exgcd(ll a,ll b,ll &x,ll &y){if(!b){x=1;y=0;return a;}ll d=exgcd(b,a%b,x,y);ll z=x;x=y;y=z-a/b*y;return d; } void works(ll a,ll b,ll p){ll x,y;ll d=exgcd(a,p,x,y);if(b%d){printf("-1\n");return;}x*=b/d;y*=b/d;printf("%lld\n",(x%(d*p)+d*p)%(d*p)+1); } ll work(ll a,ll b,ll p){if(!a&&!b)return 1;if(!a)return -2;ll t=sqrt(p)+1;v.clear();for(ll i=0,z=1;i<t;i++,z=z*a%p)v[z*b%p]=i;a=power(a,t);if(b==1||!a)return 1;else if(!a)return -2;ll ans=1e18;for(ll i=0,tmp=1;i<=t;i++,tmp=tmp*a%p){ll j=(v.find(tmp)!=v.end())?v[tmp]:-1;if(j>=0&&i*t-j>=0)ans=min(ans,i*t-j);}if(ans==1e18)return -2;return ans; } signed main() {scanf("%lld",&T);while(T--){scanf("%lld%lld%lld%lld%lld",&p,&a,&b,&x,&t);if(!a&&!t&&b){puts("-1");continue;}if(x==t){puts("1");continue;}if(a==1){works(b,(t-x+p)%p,p);continue;}t=(t*(a-1)+b)%p;x=(x*a-x+b+p)%p;t=t*power(x,p-2)%p;t=(t+p)%p;printf("%lld\n",work(a,t,p)+1);}return 0; }

總結

以上是生活随笔為你收集整理的P3306-[SDOI2013]随机数生成器【BSGS】的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: www.麻豆av | 国产日韩欧美一区二区 | 国产日本欧美在线观看 | 五月依人网 | 小h片在线观看 | 亚洲人掀裙打屁股网站 | 怎么可能高潮了就结束漫画 | 免费一级黄色大片 | 日韩视频一区 | 欧美一区精品 | 日韩男女视频 | 欧美a√在线 | 折磨小男生性器羞耻的故事 | 97在线观看免费视频 | 欧美一级在线免费 | 精品成在人线av无码免费看 | 久久久久逼 | 午夜影视在线观看 | 美女搞黄视频网站 | 欧美日韩性 | 国产精品一区二区三区在线播放 | 国产成人精品一区二区三区网站观看 | 91视频色版| 亚洲精品国产suv | 国产精品久久久久久久裸模 | sm国产在线调教视频 | yellow免费在线观看 | 天天干天天爱天天操 | 国产视频在线观看一区 | 污视频网站入口 | 爱爱二区| 亚洲午夜精品一区二区三区他趣 | 免费看亚洲 | 日本三级吹潮 | 夜夜操夜夜干 | 综合国产精品 | 91娇羞白丝 | 毛片一级片 | 性xxxx狂欢老少配o | 黄色三级小说 | 日韩欧美片 | 韩国一区二区三区四区 | 久久久久久蜜桃 | 亚洲精品影视 | 青草操| 九色麻豆 | 毛片a级片 | 天天爽| a级黄视频| 亚洲视频欧美视频 | 强伦人妻一区二区三区视频18 | 日韩国产欧美精品 | 国产精品97 | 国产一区二区三区日韩 | 欧美午夜在线视频 | 亚洲三级电影网站 | 先锋av在线资源 | 影音先锋久久 | 亚洲一区网站 | 少妇精品无码一区二区三区 | 精品综合久久 | 欧美a天堂 | 亚洲第一综合网站 | 国产一区二区视频在线播放 | 五月天精品 | 91欧美在线视频 | 在线观看黄网站 | 久久久久久久久久艹 | 精品自拍视频在线观看 | 99资源网 | 夜夜激情 | 日本成人免费网站 | 香蕉视频入口 | 国产精品18久久久 | 久久99热精品 | 一区二区三区美女视频 | 欧美一区二区三区影院 | 亚洲在线免费视频 | 俄罗斯一级片 | 日韩综合在线视频 | 中文字幕亚洲精品 | 五十路六十路七十路熟婆 | 国产激情福利 | www日本色| 午夜777| 就爱av | 亚洲av无码国产精品久久久久 | 欧美精品在线看 | 毛片一区| 起碰在线| 亚洲av成人一区二区 | 欧美在线一区二区三区 | 国产欧美亚洲精品 | 成年人在线视频观看 | 四虎av影视| 91精品国产精品 | 久久免费看毛片 | 亚洲无码精品一区二区三区 | 国产性猛交xx乱 |