BZOJ- 3142:數列 (數學)
阿新 • • 發佈:2018-09-19
strong 分享圖片 長度 c++ style include 數量 差分 sin
題意:給出N,K,M,P。求有多少長度為K的序列A,滿足:(1)首項為正整數;(2)遞增數列;(3)相鄰兩項的差小於等於m;(4)最後一個數小於等於N。
思路:根據差分來算數量。
#include<bits/stdc++.h> #define ll long long using namespace std; ll N,M,K,P,ans,ans2; ll qpow(ll a,ll x){ ll res=1;while(x){ if(x&1) res=(ll)res*a%P; a=(ll)a*a%P; x>>=1; }return res; } int main() { scanf("%lld%lld%lld%lld",&N,&K,&M,&P); N%=P; ans=(ll)N*qpow(M,K-1)%P; ll a=M,b=M+1; if(a&1) b/=2; else a/=2; ans2=(ll)a*b%P; ans2=(ll)ans2*qpow(M,K-2)%P*(K-1)%P; ans=(((ans-ans2)%P)+P)%P; printf("%lld\n",ans);return 0; }
BZOJ- 3142:數列 (數學)