Submission #3709126
Source Code Expand
#include<bits/stdc++.h> #define st first #define nd second #define pb push_back #define ppb pop_back #define umax(x,y) x=max(x,y) #define umin(x,y) x=min(x,y) #define ll long long #define ii pair<int,int> #define iii pair<ii,int> #define iiii pair<ii,ii> #define sz(x) ((int) x.size()) #define orta ((bas+son)>>1) #define all(x) x.begin(),x.end() #define dbgs(x) cerr<<(#x)<<" --> "<<(x)<<" " #define dbg(x) cerr<<(#x)<<" --> "<<(x)<<endl;getchar() #define pw(x) (1<<(x)) #define inf 10050000000000000 #define MOD 1000000007 #define N 200005 #define M 1000005 #define LOG 18 #define KOK 32000 using namespace std; int n,tot; int tut[N],f[N]; ll ans; char s[N]; vector<int> pos[26],rpos[26]; vector<ii> v; void up(int x) { for(int i=x;i<=n;i+=(i&-i)) f[i]++; } int get(int x) { int res=0; for(int i=x;i>=1;i-=(i&-i)) res+=f[i]; return res; } int main() { //freopen("input.txt","r",stdin); scanf("%s",s+1); n=strlen(s+1); int odd=0; for(int i=1;i<=n;i++) { pos[s[i]-'a'].pb(i); odd-=1-sz(pos[s[i]-'a'])%2; odd+=sz(pos[s[i]-'a'])%2; } if(odd>1) { printf("-1"); return 0; } for(int i=0;i<26;i++) { for(int j=0;j<sz(pos[i])/2;j++) { v.pb({pos[i][j],i}); } } sort(all(v)); for(int i=0;i<sz(v);i++) { rpos[v[i].nd].pb(++tot); } if(n%2) { for(int i=0;i<26;i++) { if(sz(pos[i])&1) { rpos[i].pb(++tot); } } } for(int i=sz(v)-1;i>=0;i--) { rpos[v[i].nd].pb(++tot); } for(int i=0;i<26;i++) { for(int j=0;j<sz(pos[i]);j++) { tut[rpos[i][j]]=pos[i][j]; } } for(int i=1;i<=n;i++) { int apos=i-1-get(tut[i]); ans+=abs(tut[i]+apos-i); up(tut[i]); } printf("%lld",ans); }
Submission Info
Submission Time | |
---|---|
Task | E - Papple Sort |
User | hamzqq9 |
Language | C++14 (GCC 5.4.1) |
Score | 800 |
Code Size | 1817 Byte |
Status | AC |
Exec Time | 19 ms |
Memory | 5364 KB |
Compile Error
./Main.cpp: In function ‘int main()’: ./Main.cpp:53:17: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result] scanf("%s",s+1); ^
Judge Result
Set Name | Sample | All | ||||
---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 800 / 800 | ||||
Status |
|
|
Set Name | Test Cases |
---|---|
Sample | s1.txt, s2.txt, s3.txt |
All | 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt, 31.txt, 32.txt, 33.txt, 34.txt, 35.txt, 36.txt, 37.txt, 38.txt, 39.txt, 40.txt, 41.txt, 42.txt, 43.txt, 44.txt, 45.txt, 46.txt, 47.txt, s1.txt, s2.txt, s3.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
01.txt | AC | 17 ms | 4596 KB |
02.txt | AC | 17 ms | 4596 KB |
03.txt | AC | 17 ms | 4596 KB |
04.txt | AC | 17 ms | 4596 KB |
05.txt | AC | 17 ms | 4596 KB |
06.txt | AC | 17 ms | 4596 KB |
07.txt | AC | 17 ms | 4596 KB |
08.txt | AC | 17 ms | 4596 KB |
09.txt | AC | 17 ms | 4596 KB |
10.txt | AC | 17 ms | 4596 KB |
11.txt | AC | 3 ms | 1408 KB |
12.txt | AC | 3 ms | 1408 KB |
13.txt | AC | 3 ms | 1408 KB |
14.txt | AC | 3 ms | 1408 KB |
15.txt | AC | 13 ms | 4468 KB |
16.txt | AC | 13 ms | 4468 KB |
17.txt | AC | 19 ms | 5232 KB |
18.txt | AC | 19 ms | 5232 KB |
19.txt | AC | 19 ms | 5076 KB |
20.txt | AC | 3 ms | 1404 KB |
21.txt | AC | 19 ms | 5056 KB |
22.txt | AC | 19 ms | 5232 KB |
23.txt | AC | 13 ms | 5108 KB |
24.txt | AC | 4 ms | 1656 KB |
25.txt | AC | 13 ms | 5364 KB |
26.txt | AC | 13 ms | 5364 KB |
27.txt | AC | 13 ms | 5236 KB |
28.txt | AC | 13 ms | 5108 KB |
29.txt | AC | 16 ms | 5236 KB |
30.txt | AC | 3 ms | 1528 KB |
31.txt | AC | 15 ms | 5236 KB |
32.txt | AC | 4 ms | 1656 KB |
33.txt | AC | 16 ms | 4852 KB |
34.txt | AC | 4 ms | 1656 KB |
35.txt | AC | 13 ms | 5108 KB |
36.txt | AC | 4 ms | 1784 KB |
37.txt | AC | 4 ms | 1488 KB |
38.txt | AC | 4 ms | 1652 KB |
39.txt | AC | 16 ms | 4976 KB |
40.txt | AC | 3 ms | 1364 KB |
41.txt | AC | 1 ms | 256 KB |
42.txt | AC | 1 ms | 256 KB |
43.txt | AC | 1 ms | 256 KB |
44.txt | AC | 1 ms | 256 KB |
45.txt | AC | 1 ms | 256 KB |
46.txt | AC | 1 ms | 256 KB |
47.txt | AC | 1 ms | 256 KB |
s1.txt | AC | 1 ms | 256 KB |
s2.txt | AC | 1 ms | 256 KB |
s3.txt | AC | 1 ms | 256 KB |