This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
//we all are lost trying to be someone
//The best way to predict the future is to create it
#include<bits/stdc++.h>
#define fastio ios_base::sync_with_stdio(0); cin.tie(0);
#define sz(x) ll(x.size())
#define all(x) x.begin(), x.end()
#define pb push_back
#define ff first
#define ss second
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<ll,ll> ii;
typedef pair<ii,ll> tri;
const ll mod=1e6+3;
const ll MAX=1e6;
ll n, k;
ll bin[MAX+20], A[MAX];
bool id[MAX+20];
ll perm(int k, int c){
ll ans=1;
for(int i=c+1; i<=k; i++){
ans*=i;
ans%=mod;
}
return ans;
}
void solve(){
cin>>n>>k;
ll aux=-1;
ll pos=0;
for(int i=0; i<n-k+1; i++){
cin>>A[i];
if(aux==-1){
aux=A[i];
continue;
}
if(aux!=A[i]){
if(!id[pos%k]){
id[pos%k]=true;
if(A[i]>aux)bin[pos%k]=0;
else bin[pos%k]=1;
}
}
aux=A[i];
pos++;
}
ll sum=0;
ll cant=0;
for(int i=0; i<k; i++){
sum+=bin[i];
if(!id[i])cant++;
//cout<<bin[i]<<' ';
}
//cout<<endl;
//cout<<cant<<' '<<A[0]-sum<<endl;
cout<<perm(cant,A[0]-sum)<<'\n';
}
int main(){
fastio;
solve();
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |