이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
const int maxn = 6e3+10;
int num[maxn], n;
void get_30(void)
{
int ans = 0, ind1 = num[1], ind2 = num[2];
for (int l = 1; l <= n; l++)
{
for (int r = l; r <= n; r++)
{
int aux = 0;
for (int i = l; i <= r; i++)
{
int x = i-l;
if (num[i] == r-x) aux++;
}
if (aux > ans)
{
ans = aux;
ind1 = num[l], ind2 = num[r];
}
}
}
cout << ind1 << " " << ind2 << "\n";
}
void get_60(void)
{
int ans = 0, ind1 = num[1], ind2 = num[2];
for (int i = 1; i <= n; i++)
{
if (num[i] < i) continue;
int aux = 0;
for (int j = i; j <= num[i]; j++)
if (num[j]+j == num[i]+i) aux++;
if (aux >= ans)
{
ans = aux;
ind1 = num[i], ind2 = num[num[i]];
}
}
for (int i = 1; i <= n; i++)
{
if (num[i] > i) continue;
int aux = 0;
for (int j = num[i]; j <= i; j++)
if (num[j]+j == num[i]+i) aux++;
if (aux >= ans)
{
ans = aux;
ind1 = num[num[i]], ind2 = num[i];
}
}
cout << ind1 << " " << ind2 << "\n";
}
int main(void)
{
ios::sync_with_stdio(false); cin.tie(0);
cin >> n;
for (int i = 1; i <= n; i++)
cin >> num[i];
if (n <= 500) get_30();
else get_60();
}
# | 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... |