Description
给出一个不规则的硬币,掷一次硬币正面概率为qpqp,问掷硬币kk次后正面出现次数为偶数的概率
Input
第一行一整数表示用例组数,每组用例输入三个整数p,q,kp,q,k(T≤100,1≤p,q,k≤107,qp≤12)(T≤100,1≤p,q,k≤107,qp≤12)
Output
输出出现偶数次正面的概率,假设答案的最简分数表示为XYXY,则输出XY−1 mod 109+7XY−1 mod 109+7后的结果
Sample Input
2
2 1 1
3 1 2
Sample Output
500000004
555555560
Solution
答案即为1pk∑i=02i≤kC2ikq2i(p−q)k−2i=12pk((q+(p−q)k+(q−(p−q))k)=pk+(p−2q)k2pk1pk∑i=02i≤kCk2iq2i(p−q)k−2i=12pk((q+(p−q)k+(q−(p−q))k)=pk+(p−2q)k2pk
Code
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<ctime>
using namespace std;
typedef long long ll;
typedef pair<int,int>P;
const int INF=0x3f3f3f3f,maxn=100001;
#define mod 1000000007
int Pow(int a,int b)
{
int ans=1;
while(b)
{
if(b&1)ans=(ll)ans*a%mod;
a=(ll)a*a%mod;
b>>=1;
}
return ans;
}
int main()
{
int T,p,q,k;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&p,&q,&k);
int ans=(ll)(Pow(p,k)+Pow(p-2*q,k))%mod*Pow(2*Pow(p,k)%mod,mod-2)%mod;
printf("%d\n",ans);
}
return 0;
}