#include <iostream>
#include <algorithm>
#include "gondola.h"
using namespace std;
#define ll long long
ll p = 1e9+9;
ll pow(ll n1, ll n2){
if(n2==0LL){return 1LL;}
else if(n2%2==0){return pow(n1*n1%p, n2/2);}
else {return n1 * pow(n1*n1%p, n2/2) %p;}
}
ll b[300005];
ll cnt[300005];
ll cha[300005];
ll brbr[300005];
ll val;
ll fin;
ll ok;
long long ans;
bool cmp(ll x, ll y){
return b[x]<b[y];
}
int valid(int n, int a[]){
ll cn=0;
ll bruh=0;
ll sp=0;
for(ll i=0; i<n; i++){
cnt[a[i]]++; if(cnt[a[i]]>1){bruh=1;}
if(a[i]<=n){cn++; sp = i;}
}
if(bruh==1){return 0;}
if(cn>0){
for(int i=0; i<n; i++){
b[(2*n+a[sp]-sp+i-1)%n] = a[i];
}
}
else {
for(int i=0; i<n; i++){b[i] = a[i];}
}
if(cn==0){return 1;}
else {
ll bru=0;
for(int i=0; i<n; i++){
if(b[i]<=n&&b[i]!=i+1){bru=1;}
}
return (1-bru);
}
}
int countReplacement(int n, int a[]){
ll n1 = valid(n, a);
if(n1==0){ return 0;}
else {
val=0;
ans=1;
for(int i=0; i<n; i++){
if(b[i]!=i+1){val++; cha[val] = i; }
}
sort(cha+1, cha+val+1, cmp);
ok = n;
for(ll i=1; i<=val; i++){
ans *= pow(val-i+1LL, b[cha[i]]-ok-1LL);
ans %= p;
ok = b[cha[i]];
}
return ans;
}
}
int replacement(int n, int a[], int c[]){
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... |
# | 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... |