正题

题目链接:https://www.luogu.com.cn/problem/P3306


题目大意

给出一个\(p,a,b,x_1,t\),有\(x_i=ax_{i-1}+b\)

求一个最小的\(n\)使得\(x_n=t\)


解题思路

下标缩一下先变成\(x_0\)会更好算一点,只考虑\(x_0\)的贡献就是\(x_0\times a^n\),这个比较好搞。

\(b\)的贡献的话,对于第\(i\)次加入的\(b\)贡献是\(a^{n-i}\)总共也就是\(b\times \sum_{i=0}^{n-1}a^i\)

通项公式一下合起来就是

\[x_0a^n+\frac{a^n-1}{a-1}b=t
\]

把\(a^n\)提到前面来就是

\[a^n=\frac{t(a-1)+b}{xa-x+b}
\]

后面那个是已知的,然后就是上\(\text{BSGS}\)就好了。

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

要特判的东西有点多就不多讲了


code

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<algorithm>
  4. #include<map>
  5. #include<cmath>
  6. #define ll long long
  7. using namespace std;
  8. ll T,p,a,b,x,t,ans;
  9. map<ll,ll> v;
  10. ll power(ll x,ll b){
  11. ll ans=1;
  12. while(b){
  13. if(b&1)ans=ans*x%p;
  14. x=x*x%p;b>>=1;
  15. }
  16. return ans;
  17. }
  18. ll exgcd(ll a,ll b,ll &x,ll &y){
  19. if(!b){
  20. x=1;y=0;
  21. return a;
  22. }
  23. ll d=exgcd(b,a%b,x,y);
  24. ll z=x;x=y;y=z-a/b*y;
  25. return d;
  26. }
  27. void works(ll a,ll b,ll p){
  28. ll x,y;
  29. ll d=exgcd(a,p,x,y);
  30. if(b%d){
  31. printf("-1\n");
  32. return;
  33. }
  34. x*=b/d;y*=b/d;
  35. printf("%lld\n",(x%(d*p)+d*p)%(d*p)+1);
  36. }
  37. ll work(ll a,ll b,ll p){
  38. if(!a&&!b)return 1;
  39. if(!a)return -2;
  40. ll t=sqrt(p)+1;v.clear();
  41. for(ll i=0,z=1;i<t;i++,z=z*a%p)
  42. v[z*b%p]=i;
  43. a=power(a,t);
  44. if(b==1||!a)return 1;
  45. else if(!a)return -2;
  46. ll ans=1e18;
  47. for(ll i=0,tmp=1;i<=t;i++,tmp=tmp*a%p){
  48. ll j=(v.find(tmp)!=v.end())?v[tmp]:-1;
  49. if(j>=0&&i*t-j>=0)ans=min(ans,i*t-j);
  50. }
  51. if(ans==1e18)return -2;
  52. return ans;
  53. }
  54. signed main()
  55. {
  56. scanf("%lld",&T);
  57. while(T--){
  58. scanf("%lld%lld%lld%lld%lld",&p,&a,&b,&x,&t);
  59. if(!a&&!t&&b){puts("-1");continue;}
  60. if(x==t){puts("1");continue;}
  61. if(a==1){
  62. works(b,(t-x+p)%p,p);
  63. continue;
  64. }
  65. t=(t*(a-1)+b)%p;x=(x*a-x+b+p)%p;
  66. t=t*power(x,p-2)%p;t=(t+p)%p;
  67. printf("%lld\n",work(a,t,p)+1);
  68. }
  69. return 0;
  70. }

P3306-[SDOI2013]随机数生成器【BSGS】的更多相关文章

  1. 洛咕 P3306 [SDOI2013]随机数生成器

    洛咕 P3306 [SDOI2013]随机数生成器 大力推式子??? \(X_{i}=\underbrace{a(a(\cdots(a(a}_{i-1个a}X_1+b)))\cdots)\) \(=b ...

  2. 【BZOJ 3122】 [Sdoi2013]随机数生成器 (BSGS)

    3122: [Sdoi2013]随机数生成器 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1442  Solved: 552 Description ...

  3. 【BZOJ3122】[Sdoi2013]随机数生成器 BSGS+exgcd+特判

    [BZOJ3122][Sdoi2013]随机数生成器 Description Input 输入含有多组数据,第一行一个正整数T,表示这个测试点内的数据组数.   接下来T行,每行有五个整数p,a,b, ...

  4. 洛谷P3306 [SDOI2013]随机数生成器(BSGS)

    传送门 感觉我BSGS都白学了……数学渣渣好像没有一道数学题能自己想出来…… 要求$X_{i+1}=aX_i+b\ (mod \ \ p)$ 左右同时加上$\frac{b}{a-1}$,把它变成等比数 ...

  5. BZOJ3122: [Sdoi2013]随机数生成器(BSGS)

    题意 题目链接 Sol 这题也比较休闲. 直接把\(X_{i+1} = (aX_i + b) \pmod P\)展开,推到最后会得到这么个玩意儿 \[ a^{i-1} (x_1 + \frac{b}{ ...

  6. bzoj 3122 : [Sdoi2013]随机数生成器 BSGS

    BSGS算法 转自:http://blog.csdn.net/clove_unique 问题 给定a,b,p,求最小的非负整数x,满足$a^x≡b(mod \ p)$ 题解 这就是经典的BSGS算法, ...

  7. 【bzoj3122】[Sdoi2013]随机数生成器 BSGS思想的利用

    题目描述 给出递推公式 $x_{i+1}=(ax_i+b)\mod p$ 中的 $p$.$a$.$b$.$x_1$ ,其中 $p$ 是质数.输入 $t$ ,求最小的 $n$ ,使得 $x_n=t$ . ...

  8. [bzoj3122][SDOI2013]随机数生成器 ——BSGS,数列

    题目大意 给定递推序列: F[i] = a*F[i-1] + b (mod c) 求一个最小的i使得F[i] == t 题解 我们首先要化简这个数列,作为一个学渣,我查阅了一些资料: http://d ...

  9. Bzoj 3122 [Sdoi2013]随机数生成器(BSGS+exgcd)

    Input 输入含有多组数据,第一行一个正整数T,表示这个测试点内的数据组数. 接下来T行,每行有五个整数p,a,b,X1,t,表示一组数据.保证X1和t都是合法的页码. 注意:P一定为质数 Outp ...

  10. P3306 [SDOI2013]随机数生成器

    思路:\(BSGS\) 提交:\(1\)次 题解: 原式可以化为\[x_{i+1}+\frac{b}{a-1}=a(x_{i}+\frac{b}{a-1})\mod p\] 这不是等比数列吗? \[x ...

随机推荐

  1. wpf 的style

    <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" x ...

  2. PL/SQL 安装使用

    PL/SQL 安装 前提:安装Oracle 使用 登录 oracle连接地址格式 ip:端口/ServerName,如192.168.136.130:1521/xe 新建菜单 Sql-Window 编 ...

  3. 【springboot】@Valid参数校验

    转自: https://blog.csdn.net/cp026la/article/details/86495659 扯淡: 刚开始写代码的时候对参数的校验要么不做.要么写很多类似 if( xx == ...

  4. spring boot 2.0.0 + shiro + redis实现前后端分离的项目

    简介 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码学和会话管理.使用Shiro的易于理解的API,您可以快速.轻松地获得任何应用程序,从最小的移动应用程序到最大 ...

  5. C# 排序列表(SortedList)

    SortedList 类代表了一系列按照键来排序的键/值对,这些键值对可以通过键和索引来访问. 排序列表是数组和哈希表的组合.它包含一个可使用键或索引访问各项的列表.如果您使用索引访问各项,则它是一个 ...

  6. 十二:Servlet3.0的注解

    1.@WebListener注解 表示的就是我们之前的在xml中配置的 <listener> <listener-class>ListenerClass</listene ...

  7. Git中使用.gitignore忽略文件的推送

    转载自:https://blog.csdn.net/lk142500/article/details/82869018 windows下可以用另存为生成gitignore 文件 1 简介 在使用Git ...

  8. 使用dom4j工具:获取xml中的标签属性(三)

    package dom4j_read; import java.io.File; import java.util.List; import org.dom4j.Attribute; import o ...

  9. JDBC基础篇(MYSQL)——使用statement执行DML语句(insert/update/delete)

    注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接: package day02_statement; import java.sql.Connection; import java.s ...

  10. Java程序设计学习笔记(二)

    --正则表达式    正则表达式         ^ 匹配的开始         $ 匹配的结束         [] 表示匹配任意一个字符             [asdasd]          ...