From c670d61a1da9696b2c1d356125ad0d70ff75798b Mon Sep 17 00:00:00 2001 From: Baoshuo Date: Sat, 18 Jun 2022 23:17:05 +0800 Subject: [PATCH] B - Circle Game https://codeforces.com/contest/1695/submission/161078137 --- Codeforces/1695/B/B.cpp | 57 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 Codeforces/1695/B/B.cpp diff --git a/Codeforces/1695/B/B.cpp b/Codeforces/1695/B/B.cpp new file mode 100644 index 00000000..81de9e83 --- /dev/null +++ b/Codeforces/1695/B/B.cpp @@ -0,0 +1,57 @@ +#include +#include + +using std::cin; +using std::cout; +const char endl = '\n'; + +const int N = 2e5 + 10; + +int t, n, a[N]; + +signed main() { + std::ios::sync_with_stdio(false); + cin.tie(nullptr); + + cin >> t; + + while (t--) { + cin >> n; + + int p = n << 1; + for (int i = 1; i <= n; i++) { + cin >> a[i]; + + if (!a[i]) p = std::min(p, i); + } + + if (p != (n << 1)) { + cout << (p & 1 ? "Joe" : "Mike") << endl; + } else if (n & 1) { + cout << "Mike" << endl; + } else { + int x = std::numeric_limits::max(), + y = std::numeric_limits::max(); + + int p1 = n, p2 = n; + for (int i = 1; i <= n; i++) { + if (i & 1) { + x = std::min(x, a[i]); + } else { + y = std::min(y, a[i]); + } + } + + for (int i = 1; i <= n; i++) { + if ((i & 1) && x == a[i]) + p1 = std::min(p1, i); + if (!(i & 1) && y == a[i]) + p2 = std::min(p2, i); + } + + cout << (x < y || x == y && p1 < p2 ? "Joe" : "Mike") << endl; + } + } + + return 0; +}