QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#785409 | #8838. Jesse's Job | Esouling | WA | 0ms | 3476kb | C++20 | 1.1kb | 2024-11-26 17:51:25 | 2024-11-26 17:51:26 |
Judging History
answer
#include <bits/stdc++.h>
using loint = long long;
using db = double;
void solve() {
int n;
std::cin >> n;
std::vector<int> a(n + 1);
for (int i = 1; i <= n; i ++) {
std::cin >> a[i];
}
int cnt = 0, cur = 1;
std::vector<int> vis(n + 1);
while (!vis[cur]) {
vis[cur] ++;
cnt ++;
cur = a[cur];
}
if (cnt != n) {
std::cout << cnt << '\n';
for (int i = 1; i <= n; i ++) {
if (vis[i]) {
std::cout << i << ' ';
}
}
std::cout << '\n';
return;
}
int ans = 0, p = 1;
for (int i = 1; i <= n; i ++) {
int l = std::min(i, a[i]), r = std::max(i, a[i]);
int len = r - l + 1;
if (n - len > ans) {
ans = n - len;
p = i;
}
}
std::cout << 1 << '\n';
std::cout << p << '\n';
}
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
std::cout.tie(0);
int _;
_ = 1;
std::cin >> _;
while(_--)
solve();
return 0;
}
详细
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 3476kb
input:
3 2 2 1 4 2 1 4 3 6 3 5 4 2 6 1
output:
1 1 2 1 2 1 3
result:
wrong answer Participant didn't find permutation (test case 1)