Submission #787936

#TimeUsernameProblemLanguageResultExecution timeMemory
787936ymmScales (IOI15_scales)C++17
0 / 100
1111 ms473372 KiB
#include "scales.h" #include <bits/stdc++.h> #define Loop(x,l,r) for (ll x = (l); x < (r); ++x) #define LoopR(x,l,r) for (ll x = (r)-1; x >= (l); --x) typedef std::pair<int,int> pii; typedef long long ll; using namespace std; typedef array<int, 6> perm; int which(const perm &p, int, int b, int c, int x) { return (x == p[b]) + 2*(x == p[c]); } tuple<int,int,int> srt(const perm &p, int a, int b, int c) { if (p[a] > p[b]) swap(a, b); if (p[b] > p[c]) swap(b, c); if (p[a] > p[b]) swap(a, b); return {a, b, c}; } int mn(const perm &p, int a, int b, int c) { int x = min({p[a], p[b], p[c]}); return which(p, a, b, c, x); } int mx(const perm &p, int a, int b, int c) { int x = max({p[a], p[b], p[c]}); return which(p, a, b, c, x); } int med(const perm &p, int a, int b, int c) { auto [x, y, z] = srt(p, a, b, c); return which(p, a, b, c, p[y]); } int nxt(const perm &p, int a, int b, int c, int d) { auto [x, y, z] = srt(p, a, b, c); if (p[d] < p[x]) return which(p, a, b, c, p[x]); if (p[d] < p[y]) return which(p, a, b, c, p[y]); if (p[d] < p[z]) return which(p, a, b, c, p[z]); return which(p, a, b, c, p[x]); } vector<tuple<int,int,int>> sel3; vector<tuple<int,int,int,int>> sel4; vector<perm> perms; int whichval(int, int b, int c, int x) { return (b == x) + 2*(c == x); } int (*f2q(int (*f)(const perm &, int, int, int)))(int, int, int) { if (f == mn) return getLightest; if (f == mx) return getHeaviest; if (f == med) return getMedian; return getMedian; } perm solve(const vector<perm> &ps) { //if (ps.size() == 0) // exit(1); //cout << ps.size() << '\n'; //for (auto p : ps) { // for (auto x : p) // cout << x << ' '; // cout << '\n'; //} if (ps.size() == 1) return ps[0]; int mnch = INT_MAX; array<vector<perm>, 3> chvec; pair<void *, void *> ch; for (auto &sel : sel4) { auto [a, b, c, d] = sel; array<vector<perm>, 3> vec; for (const auto &p : ps) vec[nxt(p, a, b, c, d)].push_back(p); int x = max({vec[0].size(), vec[1].size(), vec[2].size()}); if (x < mnch) { mnch = x; chvec = vec; ch = {(void *)getHeaviest, (void *)&sel}; } } for (auto f : {mn, mx, med}) { for (auto &sel : sel3) { auto [a, b, c] = sel; array<vector<perm>, 3> vec; for (const auto &p : ps) vec[f(p, a, b, c)].push_back(p); int x = max({vec[0].size(), vec[1].size(), vec[2].size()}); if (x < mnch) { mnch = x; chvec = vec; ch = {(void *)f2q(f), (void *)&sel}; } } } if (ch.first == getHeaviest) { //cout << "Hi\n"; auto [a, b, c, d] = *(tuple<int,int,int,int> *)ch.second; int x = getNextLightest(a+1, b+1, c+1, d+1)-1; int i = whichval(a, b, c, x); return solve(chvec[i]); } else { auto f = (int (*)(int, int, int))ch.first; auto [a, b, c] = *(tuple<int,int,int> *)ch.second; int x = f(a+1, b+1, c+1)-1; int i = whichval(a, b, c, x); return solve(chvec[i]); } } void init(int T) { Loop (i,0,6) Loop (j,i+1,6) Loop (k,j+1,6) { sel3.emplace_back(i, j, k); Loop (d,0,6) { if (i != d && j != d && k != d) sel4.emplace_back(i, j, k, d); } } perm p = {0, 1, 2, 3, 4, 5}; do perms.push_back(p); while (next_permutation(p.begin(), p.end())); } void orderCoins() { auto ans = solve(perms); int w[6]; Loop (i,0,6) w[ans[i]] = i+1; answer(w); }

Compilation message (stderr)

scales.cpp: In function 'perm solve(const std::vector<std::array<int, 6> >&)':
scales.cpp:76:14: warning: conversion from 'long unsigned int' to 'int' may change value [-Wconversion]
   76 |   int x = max({vec[0].size(), vec[1].size(), vec[2].size()});
      |           ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
scales.cpp:89:15: warning: conversion from 'long unsigned int' to 'int' may change value [-Wconversion]
   89 |    int x = max({vec[0].size(), vec[1].size(), vec[2].size()});
      |            ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
scales.cpp: In function 'void init(int)':
scales.cpp:112:15: warning: unused parameter 'T' [-Wunused-parameter]
  112 | void init(int T) {
      |           ~~~~^
scales.cpp: In function 'void orderCoins()':
scales.cpp:130:16: warning: conversion from 'll' {aka 'long long int'} to 'int' may change value [-Wconversion]
  130 |   w[ans[i]] = i+1;
      |               ~^~
#Verdict Execution timeMemoryGrader output
Fetching results...