1. 程式人生 > >BZOJ- 3142:數列 (數學)

BZOJ- 3142:數列 (數學)

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:數列 (數學)