This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#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 (are_connected({path[0][0], path[0].back()}, {path[1][0], path[1].back()}) || true) {
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... |