容易发现,对于牌堆里第x张牌,在一次洗牌后会变成2*x%(n+1)的位置。

于是问题就变成了求x*2^m%(n+1)=L,x在[1,n]范围内的解。

显然可以用扩展欧几里得求出。

# include <cstdio>
# include <cstring>
# include <cstdlib>
# include <iostream>
# include <vector>
# include <queue>
# include <stack>
# include <map>
# include <bitset>
# include <set>
# include <cmath>
# include <algorithm>
using namespace std;
# define lowbit(x) ((x)&(-x))
# define pi acos(-1.0)
# define eps 1e-
# define MOD
# define INF
# define mem(a,b) memset(a,b,sizeof(a))
# define FOR(i,a,n) for(int i=a; i<=n; ++i)
# define FO(i,a,n) for(int i=a; i<n; ++i)
# define bug puts("H");
# define lch p<<,l,mid
# define rch p<<|,mid+,r
# define mp make_pair
# define pb push_back
typedef pair<int,int> PII;
typedef vector<int> VI;
# pragma comment(linker, "/STACK:1024000000,1024000000")
typedef long long LL;
int Scan() {
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
const int N=;
//Code begin... LL mult_mod(LL a, LL b, LL c){
a%=c; b%=c;
LL ret=, tmp=a;
while (b){
if (b&) {
ret+=tmp;
if (ret>c) ret-=c;
}
tmp<<=;
if (tmp>c) tmp-=c;
b>>=;
}
return ret;
}
LL pow_mod(LL a, LL n, LL mod){
LL ret=, temp=a%mod;
while (n) {
if (n&) ret=mult_mod(ret,temp,mod);
temp=mult_mod(temp,temp,mod);
n>>=;
}
return ret;
}
LL extend_gcd(LL a, LL b, LL &x, LL &y){
if (a==&&b==) return -;
if (b==) {x=; y=; return a;}
LL d=extend_gcd(b,a%b,y,x);
y-=a/b*x;
return d;
}
int main ()
{
LL n, m, l, a, b, d, x, y, mod;
scanf("%lld%lld%lld",&n,&m,&l);
a=pow_mod(,m,n+); b=n+;
d=extend_gcd(a,b,x,y); x=x*l/d; mod=b/d;
x=(x%mod+mod)%mod;
printf("%lld\n",x);
return ;
}

最新文章

  1. 搭建自己的LAMP
  2. [转载]再来重新认识JavaEE完整体系架构
  3. [知识点]C++中的运算符
  4. 生成器(generator)内部解析
  5. sql读取xml
  6. JS日期(Date)处理函数总结
  7. WiFi Test Entity
  8. h5拖放-拖拽购物车
  9. [原] Unity下的ElectroServer的连接
  10. win10 pro eclipse maven: Cannot read lifecycle mapping metadata for artifact org.apache.maven.plugins:mav invalid END header (bad central directory offset)
  11. DataTableToList
  12. geopyspark入门
  13. 细说Cookie--转
  14. MySQL 和 Oracle 在 MyBatis 使用中的区别
  15. 杰克.多西 twitter创始人 必做清单和不必做清单
  16. 备份时如何排除掉默认的 information_schema 和 mysql 库?
  17. Python3 socketserver模块
  18. css border
  19. Struts2配置文件struts.xml的编辑自动提示代码功能
  20. .net多线程,线程异步,线程同步,并发问题---1---ShinePans

热门文章

  1. 20145226夏艺华 网络对抗技术 EXP7 网络欺诈技术防范
  2. day 8 list列表
  3. php S3调用SDK示例 AmazonS3
  4. Hibernate各种主键生成策略与配置详解(转)
  5. C# 多线程的等待所有线程结束的一个问题
  6. PHP序列化serialize()和反序列化unserialize()
  7. [C++]C++得到最大的int值
  8. Loadrunner教程--常用操做流程
  9. 【RL系列】On-Policy与Off-Policy
  10. Fiber Network ZOJ 1967(Floyd+二进制状态压缩)