bzoj 1965: [Ahoi2005]SHUFFLE 洗牌
来源:互联网 发布:淘宝网斜挎包包 编辑:程序博客网 时间:2024/05/20 07:16
题意:
xjb洗m次扑克,问第l为上的数是什么。
题解:
第一眼数据范围,什么,好大啊,
一开始我是这么想的,写个递推,然后找循环节优化。
递推还是蛮好写的:
LL f(LL i,LL j){ if(i==0) return j; if(j%2==0) return f(i-1,j/2); else return f(i-1,(j+1+n)/2);}
但是好像不可优化啊。可能是我太菜了
于是换一种思维,从前往后推,考虑第x位上的数经过一次洗牌后到哪一位。
得到
整理得到
所以列出同余方程
扩展欧几里得直接上就好了。
code:
#include<cstdio>#include<cstdlib>#include<iostream>#define LL long longusing namespace std;LL mod;LL n,m,l;LL exgcd(LL a,LL b,LL &x,LL &y){ if(a==0){x=0;y=1;return b;} LL tx,ty,d; d=exgcd(b%a,a,tx,ty); x=ty-(b/a)*tx;y=tx; return d;}LL cheng(LL a,LL b){ LL ans=0; while(b) { if(b&1) (ans+=a)%=mod;; (a+=a)%=mod;b>>=1; } return ans;}LL quick(LL a,LL b){ LL ans=1LL; while(b) { if(b&1) ans=cheng(ans,a); a=cheng(a,a);b>>=1; } return ans;}int main(){ scanf("%lld %lld %lld",&n,&m,&l); mod=n+1; LL A=quick(2LL,m),B=mod,C=l; LL x,y,d=exgcd(A,B,x,y); printf("%lld",(x*(C/d)%(B/d)+(B/d))%(B/d));}
阅读全文
0 0
- bzoj 1965: [Ahoi2005]SHUFFLE 洗牌
- BZOJ 1965 AHOI2005 SHUFFLE 洗牌 数论
- 【逆元】【bzoj 1965】: [Ahoi2005]SHUFFLE 洗牌
- [BZOJ]1965: [Ahoi2005]SHUFFLE 洗牌 扩展欧几里得
- 1965: [Ahoi2005]SHUFFLE 洗牌
- 1965: [Ahoi2005]SHUFFLE 洗牌
- bzoj 1965: [Ahoi2005]SHUFFLE 洗牌 (快速幂)
- BZOJ 1965: [Ahoi2005]SHUFFLE 洗牌 快速幂 快速乘
- 【BZOJ】【P1965】【AHOI2005】【SHUFFLE 洗牌】【题解】【数论】
- bzoj1965: [Ahoi2005]SHUFFLE 洗牌
- [BZOJ1965][Ahoi2005]SHUFFLE 洗牌
- BZOJ1965: [Ahoi2005]SHUFFLE 洗牌
- bzoj1965 [Ahoi2005]SHUFFLE 洗牌
- bzoj1965: [Ahoi2005]SHUFFLE 洗牌
- BZOJ1965 [Ahoi2005]SHUFFLE 洗牌
- BZOJ 1965 SHUFFLE 洗牌
- 1965: [Ahoi2005]SHUFFLE 洗牌 快速幂+扩展欧几里得算法
- 【bzoj1965】【Ahoi2005】【SHUFFLE 洗牌】【快速幂】
- log4详细配置
- phpcms v9 专题添加自定义字段及其调用
- 685
- HDU 4677 Query on Graph 并查集+分块
- 日常知识整理---web项目字典设计与管理
- bzoj 1965: [Ahoi2005]SHUFFLE 洗牌
- 取list中的值时候总是取到第一个值
- CSS 元素垂直居中的 6种方法
- java5的拆箱与装箱
- FreeRTOS入门学习记录2——队列管理
- Tomcat配置虚拟路径
- Nessus 漏洞扫描软件安装使用
- Super Jumping! Jumping! Jumping! dp
- c#获取当前日期时间