QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#823348 | #8428. Partition into Teams | Aurore | TL | 0ms | 0kb | C++23 | 1.6kb | 2024-12-20 22:21:28 | 2024-12-20 22:21:29 |
answer
#include<bits/stdc++.h>
#define int long long
using namespace std;
inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-f;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int buf[30];
inline void print(int x,char ch=' '){
if(x<0) putchar('-'),x=-x;
int tot=0;
do{
buf[++tot]=x%10;
x/=10;
}while(x);
for(int i=tot;i>=1;i--)
putchar(buf[i]+'0');
putchar(ch);
}
const int MAXN=1e6+5;
int n,mod;
int qpow(int a,int b){
int ans=1,base=a;
while(b){
if(b&1) ans=ans*base%mod;
base=base*base%mod;
b>>=1;
}
return ans;
}
int fac[MAXN],inv[MAXN];
int c(int n,int m){
if(n<m) return 0;
return fac[n]*inv[m]%mod*inv[n-m]%mod;
}
void init(){
fac[0]=1;
for(int i=1;i<=n;i++)
fac[i]=fac[i-1]*i%mod;
inv[0]=inv[1]=1;
for(int i=2;i<=n;i++)
inv[i]=inv[mod%i]*(mod-mod/i)%mod;
for(int i=1;i<=n;i++)
inv[i]=inv[i-1]*inv[i]%mod;
}
int a[MAXN],m;
int calc(int n){
do{
a[++m]=n%mod;
n/=mod;
}while(n);
}
int f[MAXN][2][2];
void add(int &x,int y){
x=(x+y)%mod;
}
int solve(){
calc(n);
f[0][0][0]=1;
for(int d=0;d<60;d++){
for(int j=0;j<2;j++){
for(int k=0;k<2;k++){
if(!f[d][j][k]) continue;
for(int i=0;i<9;i++){
int x=i,y=(i*2+k)%10,z=a[d+1];
if((!j&&x>z)||(j&&x>=z))
add(f[d+1][1][(i*2+k)>=10],f[d][j][k]*c(z,y)%mod*c(y,x));
else
add(f[d+1][0][(i*2+k)>=10],f[d][j][k]*c(z,y)%mod*c(y,x));
}
}
}
}
return f[60][0][0];
}
signed main(){
n=read(),mod=read();
init();
print((qpow(3,n)-solve()+mod)*qpow(2,mod-2)%mod);
return 0;
}
詳細信息
Test #1:
score: 0
Time Limit Exceeded
input:
5 5