이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#include "longesttrip.h"
using namespace std;
vector<int> longest_trip(int N, int D)
{
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
vector<int> path[2];
path[0] = {0};
for (int i = 1; i < N; i++) {
bool which = uniform_int_distribution<int>(0, 1)(rng);
if (path[which].empty()) {
which = !which;
}
if (are_connected({path[which].back()}, {i})) {
path[which].push_back(i);
if (!path[!which].empty() &&
are_connected({path[!which].back()}, {i})) {
while (!path[!which].empty()) {
path[which].push_back(path[!which].back());
path[!which].pop_back();
}
}
}
else {
path[!which].push_back(i);
}
}
if (path[0].empty()) {
return path[1];
}
if (path[1].empty()) {
return path[0];
}
vector<int> res;
if (true || are_connected({path[0][0], path[0].back()}, {path[1][0], path[1].back()})) {
if (are_connected({path[0][0]}, {path[1][0]})) {
for (int i: path[1]) {
res.push_back(i);
}
reverse(res.begin(), res.end());
for (int i: path[0]) {
res.push_back(i);
}
}
else if(are_connected({path[0][0]}, {path[1].back()})) {
for (int i: path[1]) {
res.push_back(i);
}
for (int i: path[0]) {
res.push_back(i);
}
}
else if(are_connected({path[0].back()}, {path[1][0]})) {
for (int i: path[0]) {
res.push_back(i);
}
for (int i: path[1]) {
res.push_back(i);
}
}
else {
res = (path[0].size() > path[1].size())?path[0] : path[1];
}
}
else {
res = (path[0].size() > path[1].size())?path[0] : path[1];
}
return res;
}
# | 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... |