120132024-11-24 21:02:49szasztundeInverziócpp17Accepted 50/50193ms5688 KiB
#include <iostream>
using namespace std;

int a[500001]={0};

int main()
{
    int n,x;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>x;
        a[x]=i;
    }
    int maxt=0, indb, indj;
    x=1;
    for(int i=2;i<=n;i++)
    {
            if(a[i]<a[x])
            {
                int d=a[x]-a[i];
                if(d>maxt)
                {
                    maxt=d; indb=x; indj=i;
                }
            }
            else x=i;

    }
    if(maxt>0)
        cout<<a[indj]<<" "<<a[indb]<<endl;
    else
        cout<<-1;


    return 0;
}
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms320 KiB
2Accepted0/017ms856 KiB
3Accepted1/11ms320 KiB
4Accepted2/21ms508 KiB
5Accepted7/72ms320 KiB
6Accepted2/217ms828 KiB
7Accepted2/2179ms5512 KiB
8Accepted2/2186ms5536 KiB
9Accepted2/2187ms5672 KiB
10Accepted2/2180ms5664 KiB
11Accepted2/2180ms5660 KiB
12Accepted2/2178ms5516 KiB
13Accepted2/2180ms5468 KiB
14Accepted2/2180ms5432 KiB
15Accepted2/2193ms5688 KiB
16Accepted2/2181ms5528 KiB
17Accepted2/2184ms5432 KiB
18Accepted2/2180ms5432 KiB
19Accepted3/3179ms5432 KiB
20Accepted3/3178ms5536 KiB
21Accepted2/2178ms5496 KiB
22Accepted2/2180ms5432 KiB
23Accepted2/2180ms5432 KiB
24Accepted2/2187ms5432 KiB