zoukankan      html  css  js  c++  java
  • [SDOI2013] 随机数生成器

    题意:

    给定$a,b,p,x_1$,$forall i>1,x_i = ax_{i-1} +b$。

    求最小的$i$满足$x_i = t$,若无解则输出-1。

    $0leq a,b,x_1 , t<pleq 10^{9},p是质数$。

    题解:

    挺水的一道题,展开之后BSGS即可。

    但$aleq 1$的地方需要特判,还巨复杂,有高中数学题内味了。

    复杂度$O(sqrt{p})$。

    套路:

    • 推式子时:注意特判整体乘除0的情况。

    代码:

    #include<bits/stdc++.h>
    #define maxn 200005
    #define maxm 500005
    #define inf 0x7fffffff
    #define ll long long
    #define rint register int
    #define debug(x) cerr<<#x<<": "<<x<<endl
    #define fgx cerr<<"--------------"<<endl
    #define dgx cerr<<"=============="<<endl
    
    using namespace std;
    ll p; unordered_map<ll,ll> M;
    
    inline ll read(){
        ll x=0,f=1; char c=getchar();
        for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
        for(;isdigit(c);c=getchar()) x=x*10+c-'0';
        return x*f;
    }
    
    inline ll pw(ll a,ll b){ll r=1;while(b)r=(b&1)?r*a%p:r,a=a*a%p,b>>=1;return r;}
    inline ll inv(ll x){return pw(x,p-2);}
    
    inline ll BSGS(ll a,ll b){
        M.clear(); ll n=ceil(sqrt(p)),ans=1ll<<62;
        for(ll i=0,t=1;i<=n;i++,t=t*a%p) M[b*t%p]=i;
        for(ll i=0,t=1,w=pw(a,n);i<=n;i++,t=t*w%p)
            if(M[t] && i*n-M[t]>=0) ans=min(ans,i*n-M[t]);
        if(ans==(1ll<<62)) return -1;
        else return ans;
    }
    
    int main(){
        //freopen("P3306_2.in","r",stdin);
        //freopen("1.out","w",stdout);
        ll T=read();
        while(T--){
            p=read(); ll a=read(),b=read(),x1=read(),t=read();
            if(a==0){
                if(x1==t) printf("1
    ");
                else if(b==t) printf("2
    ");
                else printf("-1
    ");
            }
            else if(a==1){
                if(b==0){
                    if(x1==t) printf("1
    ");
                    else printf("-1
    ");
                }
                else printf("%lld
    ",(t-x1+p)*inv(b)%p+1);
            }
            else{
                if((x1+(b*inv(a-1)))%p==0){
                    if((t+(b*inv(a-1)))%p==0) printf("1
    ");
                    else printf("-1
    ");
                }
                else{
                    ll y=(t+(b*inv(a-1)))%p*inv((x1+(b*inv(a-1)))%p)%p;
                    ll ans=BSGS(a,y)+1;
                    if(ans==0) printf("-1
    "); 
                    else printf("%lld
    ",ans);
                }
            }
        }
        return 0;
    }
    //59 38 24 25 5
    随机数生成器
  • 相关阅读:
    redis的发布订阅模式pubsub
    django集成celery之callback方式link_error和on_failure
    linux命令和awk
    使用beanstalkd实现定制化持续集成过程中pipeline
    JavaScript实现模糊推荐的input框(类似百度搜索框)
    hadoop streaming编程小demo(python版)
    一个scrapy框架的爬虫(爬取京东图书)
    mongodb生产环境(副本集模式)集群搭建配置
    TensorFlow加载图片的方法
    STC15W408AS简单使用教程-简单的光强检测!
  • 原文地址:https://www.cnblogs.com/YSFAC/p/13231571.html
Copyright © 2011-2022 走看看