245072026-02-12 09:57:29Pedri26KörJáték (50 pont)cpp17Elfogadva 50/508ms1080 KiB
// Source: https://usaco.guide/general/io

#include <bits/stdc++.h>
using namespace std;
int n, poz[30002], a[30002], tav[30002];

int main() {
	
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
        poz[a[i]]=i;
    }
    int s=0;
    for(int i=1;i<n;i++)
    {
        if(poz[i]>poz[i+1])
        {
            s+=n+poz[i+1]-poz[i];
            tav[i]=n+poz[i+1]-poz[i];
        }
        else 
        {
            s+=poz[i+1]-poz[i];
            tav[i]=poz[i+1]-poz[i];
        }
    }
    for(int i=1;i<=n;i++)
    {
        int s1=s;
        s1-=tav[a[i]];
        if(a[i]!=1)s1-=tav[a[i]-1];
        poz[n+1]=poz[n];
        if(a[i]!=1){
            if(poz[a[i]+1]>=poz[a[i]-1])
            {
                s1+=poz[a[i]+1]-poz[a[i]-1];
                //cout<<poz[a[i]+1]<<" "<<poz[a[i]-1]<<endl;
            }
            else
            {
                s1+=n+poz[a[i]+1]-poz[a[i]-1];
            }
        }
        if(poz[a[i]]>=poz[n])
        {
            s1+=poz[a[i]]-poz[n];
        }
        else 
        {
            s1+=n+poz[a[i]]-poz[n];
        }
        cout<<s1<<" ";
    }
    

    
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base50/50
1Elfogadva0/01ms508 KiB
2Elfogadva0/01ms316 KiB
3Elfogadva0/01ms316 KiB
4Elfogadva2/21ms316 KiB
5Elfogadva2/21ms316 KiB
6Elfogadva2/21ms316 KiB
7Elfogadva2/21ms316 KiB
8Elfogadva2/21ms316 KiB
9Elfogadva2/21ms316 KiB
10Elfogadva2/21ms316 KiB
11Elfogadva2/21ms508 KiB
12Elfogadva2/21ms316 KiB
13Elfogadva2/21ms316 KiB
14Elfogadva2/21ms316 KiB
15Elfogadva2/21ms316 KiB
16Elfogadva1/11ms316 KiB
17Elfogadva2/28ms1076 KiB
18Elfogadva2/28ms1080 KiB
19Elfogadva2/26ms820 KiB
20Elfogadva2/27ms1076 KiB
21Elfogadva2/27ms820 KiB
22Elfogadva2/27ms1080 KiB
23Elfogadva2/27ms820 KiB
24Elfogadva2/27ms1076 KiB
25Elfogadva2/28ms1076 KiB
26Elfogadva2/28ms1076 KiB
27Elfogadva2/28ms1076 KiB
28Elfogadva2/28ms1076 KiB
29Elfogadva1/17ms972 KiB