题目链接

BZOJ4830

题解

当\(a = b\)时,我们把他们投掷硬币的结果表示成二进制,发现,当\(A\)输给\(B\)时,将二进制反转一下\(A\)就赢了\(B\)

还要除去平局的情况,最后答案就是

\[\frac{2^{a + b} - {a + b \choose a}}{2}
\]

当\(a \neq b\)时,有些状态可能翻转后还是\(A\)赢\(B\),需要加上这部分

\[\begin{aligned}
\sum\limits_{i = 0}^{b} \sum\limits_{j = 1}^{a - b - 1}{b \choose i} {a \choose i + j}
&= \sum\limits_{j = 1}^{a - b - 1} \sum\limits_{i = 0}^{b} {b \choose b - i} {a \choose i + j} \\
&= \sum\limits_{j = 1}^{a - b - 1} {a + b \choose b + j} \\
&= \sum\limits_{j = b + 1}^{a - 1} {a + b \choose j} \\
\end{aligned}
\]

答案是

\[\frac{2^{a + b} + \sum\limits_{j = b + 1}^{a - 1} {a + b \choose j} }{2}
\]

除\(2\)的处理,因为组合数是对称的,所以只算一半

如果中间单独剩一个,一定可以被\(2\)整除,处理因子时减去一个即可

由于要模\(10^{K}\),组合数的计算用扩展\(Lucas\)

此题非常卡常,要使用扩展\(Lucas\)的一些优化

1.预处理阶乘

2.当\(p\)的幂次大于\(k\)时直接返回\(0\)

3.没了

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<iomanip>
#include<cstdio>
#include<vector>
#include<queue>
#include<ctime>
#include<cmath>
#include<map>
#define LL long long int
#define REP(i,n) for (LL i = 1; i <= (n); i++)
#define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
#define cls(s,v) memset(s,v,sizeof(s))
#define mp(a,b) make_pair<int,int>(a,b)
#define cp pair<int,int>
using namespace std;
const int maxn = 2000005,maxm = 100005,INF = 0x3f3f3f3f;
int K,pr[2],pk[2],P,fac[2][maxn],now,ans;
LL A,B;
void init(){
pr[0] = 2; pr[1] = 5; pk[0] = pk[1] = P = fac[0][0] = fac[1][0] = 1;
REP(i,K) pk[0] *= 2,pk[1] *= 5,P *= 10;
for (LL i = 1; i < pk[0]; i++)
if (i % 2) fac[0][i] = 1ll * fac[0][i - 1] * i % pk[0];
else fac[0][i] = fac[0][i - 1];
for (LL i = 1; i < pk[1]; i++)
if (i % 5) fac[1][i] = 1ll * fac[1][i - 1] * i % pk[1];
else fac[1][i] = fac[1][i - 1];
}
inline int qpow(int a,LL b,int p){
int re = 1;
for (; b; b >>= 1,a = 1ll * a * a % p)
if (b & 1) re = 1ll * re * a % p;
return re;
}
inline void exgcd(int a,int b,int&d ,int& x,int& y){
if (!b){d = a; x = 1; y = 0;}
else exgcd(b,a % b,d,y,x),y -= (a / b) * x;
}
inline int inv(int n,int p){
int d,x,y; exgcd(n,p,d,x,y);
return (x % p + p) % p;
}
int Fac(LL n,int pk,int p){
if (!n) return 1;
return 1ll * qpow(fac[now][pk - 1],n / pk,pk) * fac[now][n % pk] % pk * Fac(n / p,pk,p) % pk;
}
int C(LL n,LL m,int pk,int p,bool f){
LL k = 0;
for (LL i = n; i; i /= p) k += i / p;
for (LL i = m; i; i /= p) k -= i / p;
for (LL i = n - m; i; i /= p) k -= i / p;
if (p == 2 && f) k--;
if (k >= 9) return 0;
now = (p == 5);
LL a = Fac(n,pk,p),b = Fac(m,pk,p),c = Fac(n - m,pk,p),ans;
ans = a * inv(b,pk) % pk * inv(c,pk) % pk;
if (p == 5 && f) ans = 1ll * ans * inv(2,pk) % P;
ans = ans * qpow(p,k,pk) % pk;
return ans * (P / pk) % P * inv(P / pk,pk) % P;
}
int exlucas(LL n,LL m,bool f){
if (m > n) return 0;
int re = 0;
re = (re + C(n,m,pk[0],pr[0],f)) % P;
re = (re + C(n,m,pk[1],pr[1],f)) % P;
return re;
}
int main(){
//double t = clock();
K = 9; init();
while (~scanf("%lld%lld%d",&A,&B,&K)){
ans = qpow(2,A + B - 1,P);
if (A == B) ans = ((ans - exlucas(A + B,A,1)) % P + P) % P;
else {
for (LL i = ((A + B) >> 1) + 1; i < A; i++){
ans = (ans + exlucas(A + B,i,0)) % P;
}
if ((A + B) % 2 == 0) ans = (ans + exlucas(A + B,(A + B) >> 1,1)) % P;
}
int md = qpow(10,K,INF); ans %= md;
while (ans < md / 10) putchar('0'),md /= 10;
printf("%d\n",ans);
}
//cerr << (clock() - t) / CLOCKS_PER_SEC << endl;
return 0;
}

BZOJ4830 [Hnoi2017]抛硬币 【扩展Lucas】的更多相关文章

  1. bzoj4830 hnoi2017 抛硬币

    题目描述 小 A 和小 B 是一对好朋友,他们经常一起愉快的玩耍.最近小 B 沉迷于**师手游,天天刷本,根本无心搞学习.但是已经入坑了几个月,却一次都没有抽到 SSR,让他非常怀疑人生.勤勉的小 A ...

  2. bzoj 4830: [Hnoi2017]抛硬币 [范德蒙德卷积 扩展lucas]

    4830: [Hnoi2017]抛硬币 题意:A投a次硬币,B投b次硬币,a比b正面朝上次数多的方案数,模\(10^k\). \(b \le a \le b+10000 \le 10^{15}, k ...

  3. 【BZOJ4830】[HNOI2017]抛硬币(组合计数,拓展卢卡斯定理)

    [BZOJ4830][HNOI2017]抛硬币(组合计数,拓展卢卡斯定理) 题面 BZOJ 洛谷 题解 暴力是啥? 枚举\(A\)的次数和\(B\)的次数,然后直接组合数算就好了:\(\display ...

  4. [AH2017/HNOI2017]抛硬币(扩展lucas)

    推式子+exlucas. 题意: 小 A 和小 B 是一对好朋友,两个人同时抛 b 次硬币,如果小 A 的正面朝上的次数大于小 B 正面朝上的次数,则小 A 获胜. 小 A 决定在小 B 没注意的时候 ...

  5. 洛谷P3726 [AH2017/HNOI2017]抛硬币(组合数+扩展Lucas)

    题面 传送门 题解 果然--扩展\(Lucas\)学了跟没学一样-- 我们先考虑\(a=b\)的情况,这种情况下每一个\(A\)胜的方案中\(A\)和\(B\)的所有位上一起取反一定是一个\(A\)败 ...

  6. [luogu3726 HNOI2017] 抛硬币 (拓展lucas)

    传送门 数学真的太优秀了Orz 数据真的太优秀了Orz 题目描述 小 A 和小 B 是一对好朋友,他们经常一起愉快的玩耍.最近小 B 沉迷于**师手游,天天刷本,根本无心搞学习.但是已经入坑了几个月, ...

  7. bzoj 4830: [Hnoi2017]抛硬币

    Description 小A和小B是一对好朋友,他们经常一起愉快的玩耍.最近小B沉迷于**师手游,天天刷本,根本无心搞学习.但是 已经入坑了几个月,却一次都没有抽到SSR,让他非常怀疑人生.勤勉的小A ...

  8. 【刷题】BZOJ 4830 [Hnoi2017]抛硬币

    Description 小A和小B是一对好朋友,他们经常一起愉快的玩耍.最近小B沉迷于**师手游,天天刷本,根本无心搞学习.但是已经入坑了几个月,却一次都没有抽到SSR,让他非常怀疑人生.勤勉的小A为 ...

  9. [AH/HNOI2017]抛硬币

    题目描述 小 A 和小 B 是一对好朋友,他们经常一起愉快的玩耍.最近小 B 沉迷于**师手游,天天刷本,根本无心搞学习.但是已经入坑了几个月,却一次都没有抽到 SSR,让他非常怀疑人生.勤勉的小 A ...

随机推荐

  1. 2017-2018-2 20155204《网络对抗技术》EXP5 MSF基础应用

    一.基础问题回答 用自己的话解释什么是exploit,payload,encode exploit:利用靶机系统中的一些漏洞进行攻击的过程,除去前期准备的工作,这一步是实施攻击. payload:载荷 ...

  2. 实践:IIS7下访问ashx页面,显示404

    问题描述 1.路径什么的都对,这方面的原因就不要想了 2.在我的电脑上可以,在同事的电脑上不可以 方案1:未注册ashx的处理应用程序 也就是不知道IIS不知道用什么应用程序处理ashx文件,解决办法 ...

  3. 【SP1811】LCS - Longest Common Substring

    [SP1811]LCS - Longest Common Substring 题面 洛谷 题解 建好后缀自动机后从初始状态沿着现在的边匹配, 如果失配则跳它的后缀链接,因为你跳后缀链接到达的\(End ...

  4. ubuntu下安装搜狗输入法

    1.如果系统中未安装依赖fcitx,libssh2-1,或者依赖fcitx,libssh2-1的版本低的话,则需提前安装或者升级,否则安装输入法时会出错 安装命令 sudo apt-get insta ...

  5. SSRS配置1:凭证和邮件

    SSRS是微软的高度集成的报表服务,通过报表服务配置管理器(Reporting Service Configuration Manager,简称RSCM),能够轻松实现报表的配置和管理,本文主要分享凭 ...

  6. 一个Python开源项目-哈勃沙箱源码剖析(下)

    前言 在上一篇中,我们讲解了哈勃沙箱的技术点,详细分析了静态检测和动态检测的流程.本篇接着对动态检测的关键技术点进行分析,包括strace,sysdig,volatility.volatility的介 ...

  7. 在Microsoft Dynamic 365/2016环境使用LinqPad查询数据(不使用linqpad Microsoft Dynamic 365 Driver)

    在Microsoft Dynamic 365/2016环境使用LinqPad查询数据 老规矩,先上效果图: 实体集合: 实体属性: 属性值:  查询出的结果可以导出的格式: 操作步骤: 1.下载Lin ...

  8. python3解析网页经过base64编码后的图片

    有时候我们打开网页看到的图片不是普通的url,例如:www.baidu.com/static/2.jpg,而是经过base64方式加密过的路径:例如:data:img/jpg;base64,/9j/4 ...

  9. linux中使sqlplus能够上下翻页

    安装包链接:https://pan.baidu.com/s/1WsQTeEQClM88aEqIvNi2ag 提取码:s241  rlwrap-0.37-1.el6.x86_64.rpm 和 rlwra ...

  10. 212. Space Replacement【LintCode by java】

    Description Write a method to replace all spaces in a string with %20. The string is given in a char ...