Submission #726757

#TimeUsernameProblemLanguageResultExecution timeMemory
726757LittleFlowers__Fun Tour (APIO20_fun)C++17
10 / 100
2082 ms1236 KiB
#include "fun.h" #include <bits/stdc++.h> using namespace std; mt19937 rng(101202); // mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); int rnd(int l,int r) { if (l > r) { cerr << l << " " << r << "\n"; } return l + rng() % (r - l + 1); } vector<int> createFunTour(int n, int q) { vector<vector<int>> distance(n, vector<int>(n)); for (int i = 0; i < n; ++i) for (int j = i + 1; j < n; ++j) { distance[i][j] = distance[j][i] = hoursRequired(i, j); } vector<int> state(n); iota(state.begin(), state.end(), 0); function<int(const vector<int>&)> evaluate = [&](const vector<int> &state) { int fault = 0; for (int i = 2; i < state.size(); ++i) { fault += distance[state[i - 2]][state[i - 1]] < distance[state[i - 1]][state[i]]; } return fault; }; int best = evaluate(state); while (best) { int x = rnd(0, n - 1); int y = rnd(0, n - 1); if (x == y) continue; swap(state[x], state[y]); int adjValue = evaluate(state); if (adjValue <= best) best = adjValue; else swap(state[x], state[y]); } return state; }

Compilation message (stderr)

fun.cpp: In lambda function:
fun.cpp:24:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   24 |     for (int i = 2; i < state.size(); ++i) {
      |                     ~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...