# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
883920 | 2023-12-06T11:55:45 Z | macneil | Let's Win the Election (JOI22_ho_t3) | C++17 | 951 ms | 600 KB |
// очень классно когда уже на втором туре сидишь сдал на 100 а твое решение тупо ломают а когда у когото n^2logn на n до 1e6 заходит всем пофиг почемуто // тут тоже кстати можно тл в два раза обрезать чтоб не расслаблялись и отжиг на еще меньше заходил ну это так идея вам для размышления #pragma GCC optimize("Ofast") #pragma GCC optimize("unroll-loops") // #pragma GCC optimize("Ofast,unroll-loops") // #pragma GCC optimize(3) // #pragma GCC optimize("Ofast") // #pragma GCC optimize("inline") // #pragma GCC optimize("-fgcse") // #pragma GCC optimize("-fgcse-lm") // #pragma GCC optimize("-fipa-sra") // #pragma GCC optimize("-ftree-pre") // #pragma GCC optimize("-ftree-vrp") // #pragma GCC optimize("-fpeephole2") // #pragma GCC optimize("-ffast-math") // #pragma GCC optimize("-fsched-spec") // #pragma GCC optimize("-falign-jumps") // #pragma GCC optimize("-falign-loops") // #pragma GCC optimize("-falign-labels") // #pragma GCC optimize("-fdevirtualize") // #pragma GCC optimize("-fcaller-saves") // #pragma GCC optimize("-fcrossjumping") // #pragma GCC optimize("-fthread-jumps") // #pragma GCC optimize("-freorder-blocks") // #pragma GCC optimize("-fschedule-insns") // #pragma GCC optimize("inline-functions") // #pragma GCC optimize("-ftree-tail-merge") // #pragma GCC optimize("-fschedule-insns2") // #pragma GCC optimize("-fstrict-aliasing") // #pragma GCC optimize("-falign-functions") // #pragma GCC optimize("-fcse-follow-jumps") // #pragma GCC optimize("-fsched-interblock") // #pragma GCC optimize("-fpartial-inlining") // #pragma GCC optimize("no-stack-protector") // #pragma GCC optimize("-freorder-functions") // #pragma GCC optimize("-findirect-inlining") // #pragma GCC optimize("-fhoist-adjacent-loads") // #pragma GCC optimize("-frerun-cse-after-loop") // #pragma GCC optimize("inline-small-functions") // #pragma GCC optimize("-finline-small-functions") // #pragma GCC optimize("-ftree-switch-conversion") // #pragma GCC optimize("-foptimize-sibling-calls") // #pragma GCC optimize("-fexpensive-optimizations") // #pragma GCC optimize("inline-functions-called-once") // #pragma GCC optimize("-fdelete-null-pointer-checks") #include <iostream> #include <vector> #include <cmath> #include <algorithm> #include <string> #include <bitset> #include <iterator> #include <iomanip> #include <map> #include <set> #include <unordered_map> #include <unordered_set> #include <ctime> #include <deque> #include <queue> #include <stack> #include <random> #include <cassert> using namespace std; // #define int long long #define pb push_back #define all(a) a.begin(), a.end() #define rall(a) a.rbegin(), a.rend() #define f(a) for(int i = 0; i<a; ++i) typedef long long ll; typedef unsigned long long ull; typedef double ld; typedef string str; typedef vector<str> vestr; typedef vector<int> vei; typedef vector<vector<int>> veve; mt19937 rnd(1329); const int NUM = 685000; int k; int gen(int n){ return min(rnd() % n, rnd() % n); } bool flip(int a, int b) { return ((rnd() % (a + b))) < a; } ld cost(vector<int> &a, vector<int> &b, vector<int> &inb, vector<int> &ord1, vector<int> &ord2) { int n = a.size(); ld ans = 0; vector<int> auu; int ttt = 1; for (auto i : ord2) { if (inb[i]) { ans += (ld)(b[i]) / (ttt); ttt++; } } int ctt = ttt - 1; for (auto i : ord1) { if (ctt == k) break; if (!inb[i]) { ans += (ld)a[i] / (ttt); ctt++; } } return ans; } void solve() { int n; cin >> n >> k; vector<int> a(n), b(n); for (int i = 0; i < n; ++i) cin >> a[i] >> b[i]; // for (int i = 0; i < n; ++i) if (b[i] == -1) b[i] = 1e14; vector<int> ord1(n), ord2(n); iota(all(ord1), 0); iota(all(ord2), 0); sort(all(ord1), [&](int i, int j){ return a[i] < a[j]; }); sort(all(ord2), [&](int i, int j){ if (b[i] == b[j]) return a[i] > a[j]; return b[i] < b[j]; }); vector<int> notminusone; for (int i = 0; i < n; ++i) if (b[i] != -1) notminusone.push_back(i); sort(all(notminusone), [&](int i, int j){ return b[i] < b[j]; }); ld ans = 0; for (int i = 0; i < k; ++i) ans += a[ord1[i]]; if (notminusone.size() == 0) { cout << ans; return; } vector<int> inb(n); // for (int i = 0; i < n; ++i) { // if (b[i] == -1) continue; // if (rnd() % 2 == 1) inb[i] = 1; // } // inb[notminusone[notminusone.size() - 1]] = 1; if (ans > cost(a, b, inb, ord1, ord2)) { ans = cost(a, b, inb, ord1, ord2); } else { inb.clear(); inb.resize(n); } ld prevans = ans; for (int i = 0; ; ++i) { vector<int> tt; for (int j = 0; j < rnd() % 5 + 1; ++j) { tt.push_back(gen(notminusone.size())); inb[notminusone[tt[j]]] ^= 1; } if (cost(a, b, inb, ord1, ord2) < prevans) { prevans = cost(a, b, inb, ord1, ord2); ans = min(ans, prevans); } else { for (auto e : tt) inb[notminusone[e]] ^= 1; } if (i % 1000 == 0) { if (clock() * 1.0 / CLOCKS_PER_SEC >= 0.95) break; } } cout << ans << '\n'; } signed main() { int tc = 1; cout << fixed << setprecision(15); #ifdef LOCAL freopen("in.txt", "r", stdin); freopen("out.txt", "w", stdout); cin >> tc; #else ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); // cin >> tc; #endif for (int t = 1; t <= tc; t++) { // cout << "Case #" << t << ": "; solve(); } }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 348 KB | Output is correct |
2 | Correct | 1 ms | 348 KB | Output is correct |
3 | Correct | 0 ms | 348 KB | Output is correct |
4 | Correct | 0 ms | 348 KB | Output is correct |
5 | Correct | 0 ms | 348 KB | Output is correct |
6 | Correct | 0 ms | 344 KB | Output is correct |
7 | Correct | 1 ms | 348 KB | Output is correct |
8 | Correct | 0 ms | 348 KB | Output is correct |
9 | Correct | 1 ms | 348 KB | Output is correct |
10 | Correct | 0 ms | 348 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 348 KB | Output is correct |
2 | Correct | 1 ms | 348 KB | Output is correct |
3 | Correct | 0 ms | 348 KB | Output is correct |
4 | Correct | 0 ms | 348 KB | Output is correct |
5 | Correct | 0 ms | 348 KB | Output is correct |
6 | Correct | 0 ms | 344 KB | Output is correct |
7 | Correct | 1 ms | 348 KB | Output is correct |
8 | Correct | 0 ms | 348 KB | Output is correct |
9 | Correct | 1 ms | 348 KB | Output is correct |
10 | Correct | 0 ms | 348 KB | Output is correct |
11 | Correct | 950 ms | 432 KB | Output is correct |
12 | Correct | 950 ms | 456 KB | Output is correct |
13 | Correct | 950 ms | 596 KB | Output is correct |
14 | Correct | 950 ms | 468 KB | Output is correct |
15 | Correct | 949 ms | 448 KB | Output is correct |
16 | Correct | 950 ms | 452 KB | Output is correct |
17 | Correct | 950 ms | 600 KB | Output is correct |
18 | Correct | 950 ms | 448 KB | Output is correct |
19 | Correct | 950 ms | 452 KB | Output is correct |
20 | Correct | 950 ms | 448 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 950 ms | 432 KB | Output is correct |
2 | Correct | 950 ms | 600 KB | Output is correct |
3 | Correct | 950 ms | 432 KB | Output is correct |
4 | Correct | 950 ms | 428 KB | Output is correct |
5 | Correct | 950 ms | 596 KB | Output is correct |
6 | Correct | 950 ms | 432 KB | Output is correct |
7 | Correct | 950 ms | 440 KB | Output is correct |
8 | Correct | 950 ms | 432 KB | Output is correct |
9 | Correct | 950 ms | 432 KB | Output is correct |
10 | Correct | 950 ms | 600 KB | Output is correct |
11 | Correct | 950 ms | 596 KB | Output is correct |
12 | Correct | 949 ms | 592 KB | Output is correct |
13 | Correct | 950 ms | 428 KB | Output is correct |
14 | Correct | 950 ms | 592 KB | Output is correct |
15 | Correct | 950 ms | 596 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 950 ms | 432 KB | Output is correct |
2 | Correct | 950 ms | 600 KB | Output is correct |
3 | Correct | 950 ms | 432 KB | Output is correct |
4 | Correct | 950 ms | 428 KB | Output is correct |
5 | Correct | 950 ms | 596 KB | Output is correct |
6 | Correct | 950 ms | 432 KB | Output is correct |
7 | Correct | 950 ms | 440 KB | Output is correct |
8 | Correct | 950 ms | 432 KB | Output is correct |
9 | Correct | 950 ms | 432 KB | Output is correct |
10 | Correct | 950 ms | 600 KB | Output is correct |
11 | Correct | 950 ms | 596 KB | Output is correct |
12 | Correct | 949 ms | 592 KB | Output is correct |
13 | Correct | 950 ms | 428 KB | Output is correct |
14 | Correct | 950 ms | 592 KB | Output is correct |
15 | Correct | 950 ms | 596 KB | Output is correct |
16 | Correct | 950 ms | 432 KB | Output is correct |
17 | Correct | 949 ms | 596 KB | Output is correct |
18 | Correct | 949 ms | 436 KB | Output is correct |
19 | Correct | 950 ms | 428 KB | Output is correct |
20 | Correct | 950 ms | 444 KB | Output is correct |
21 | Correct | 950 ms | 348 KB | Output is correct |
22 | Correct | 950 ms | 432 KB | Output is correct |
23 | Correct | 950 ms | 592 KB | Output is correct |
24 | Correct | 950 ms | 348 KB | Output is correct |
25 | Correct | 950 ms | 348 KB | Output is correct |
26 | Correct | 950 ms | 592 KB | Output is correct |
27 | Correct | 950 ms | 428 KB | Output is correct |
28 | Correct | 950 ms | 592 KB | Output is correct |
29 | Correct | 949 ms | 348 KB | Output is correct |
30 | Correct | 950 ms | 432 KB | Output is correct |
31 | Correct | 950 ms | 432 KB | Output is correct |
32 | Correct | 950 ms | 428 KB | Output is correct |
33 | Correct | 949 ms | 436 KB | Output is correct |
34 | Correct | 950 ms | 444 KB | Output is correct |
35 | Correct | 949 ms | 596 KB | Output is correct |
36 | Correct | 950 ms | 432 KB | Output is correct |
37 | Correct | 950 ms | 592 KB | Output is correct |
38 | Correct | 950 ms | 348 KB | Output is correct |
39 | Correct | 949 ms | 432 KB | Output is correct |
40 | Correct | 950 ms | 428 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 950 ms | 432 KB | Output is correct |
2 | Correct | 950 ms | 600 KB | Output is correct |
3 | Correct | 950 ms | 432 KB | Output is correct |
4 | Correct | 950 ms | 428 KB | Output is correct |
5 | Correct | 950 ms | 596 KB | Output is correct |
6 | Correct | 950 ms | 432 KB | Output is correct |
7 | Correct | 950 ms | 440 KB | Output is correct |
8 | Correct | 950 ms | 432 KB | Output is correct |
9 | Correct | 950 ms | 432 KB | Output is correct |
10 | Correct | 950 ms | 600 KB | Output is correct |
11 | Correct | 950 ms | 596 KB | Output is correct |
12 | Correct | 949 ms | 592 KB | Output is correct |
13 | Correct | 950 ms | 428 KB | Output is correct |
14 | Correct | 950 ms | 592 KB | Output is correct |
15 | Correct | 950 ms | 596 KB | Output is correct |
16 | Correct | 950 ms | 432 KB | Output is correct |
17 | Correct | 949 ms | 596 KB | Output is correct |
18 | Correct | 949 ms | 436 KB | Output is correct |
19 | Correct | 950 ms | 428 KB | Output is correct |
20 | Correct | 950 ms | 444 KB | Output is correct |
21 | Correct | 950 ms | 348 KB | Output is correct |
22 | Correct | 950 ms | 432 KB | Output is correct |
23 | Correct | 950 ms | 592 KB | Output is correct |
24 | Correct | 950 ms | 348 KB | Output is correct |
25 | Correct | 950 ms | 348 KB | Output is correct |
26 | Correct | 950 ms | 592 KB | Output is correct |
27 | Correct | 950 ms | 428 KB | Output is correct |
28 | Correct | 950 ms | 592 KB | Output is correct |
29 | Correct | 949 ms | 348 KB | Output is correct |
30 | Correct | 950 ms | 432 KB | Output is correct |
31 | Correct | 950 ms | 432 KB | Output is correct |
32 | Correct | 950 ms | 428 KB | Output is correct |
33 | Correct | 949 ms | 436 KB | Output is correct |
34 | Correct | 950 ms | 444 KB | Output is correct |
35 | Correct | 949 ms | 596 KB | Output is correct |
36 | Correct | 950 ms | 432 KB | Output is correct |
37 | Correct | 950 ms | 592 KB | Output is correct |
38 | Correct | 950 ms | 348 KB | Output is correct |
39 | Correct | 949 ms | 432 KB | Output is correct |
40 | Correct | 950 ms | 428 KB | Output is correct |
41 | Correct | 950 ms | 436 KB | Output is correct |
42 | Correct | 949 ms | 344 KB | Output is correct |
43 | Correct | 950 ms | 592 KB | Output is correct |
44 | Correct | 950 ms | 344 KB | Output is correct |
45 | Correct | 950 ms | 452 KB | Output is correct |
46 | Correct | 950 ms | 348 KB | Output is correct |
47 | Correct | 950 ms | 436 KB | Output is correct |
48 | Correct | 950 ms | 432 KB | Output is correct |
49 | Correct | 950 ms | 436 KB | Output is correct |
50 | Correct | 949 ms | 440 KB | Output is correct |
51 | Correct | 949 ms | 592 KB | Output is correct |
52 | Correct | 950 ms | 432 KB | Output is correct |
53 | Correct | 950 ms | 596 KB | Output is correct |
54 | Correct | 950 ms | 432 KB | Output is correct |
55 | Correct | 950 ms | 436 KB | Output is correct |
56 | Correct | 949 ms | 436 KB | Output is correct |
57 | Correct | 950 ms | 436 KB | Output is correct |
58 | Correct | 950 ms | 592 KB | Output is correct |
59 | Correct | 950 ms | 440 KB | Output is correct |
60 | Correct | 950 ms | 596 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 950 ms | 448 KB | Output is correct |
2 | Correct | 950 ms | 348 KB | Output is correct |
3 | Correct | 950 ms | 448 KB | Output is correct |
4 | Correct | 951 ms | 448 KB | Output is correct |
5 | Correct | 950 ms | 448 KB | Output is correct |
6 | Correct | 950 ms | 452 KB | Output is correct |
7 | Correct | 950 ms | 452 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 348 KB | Output is correct |
2 | Correct | 1 ms | 348 KB | Output is correct |
3 | Correct | 0 ms | 348 KB | Output is correct |
4 | Correct | 0 ms | 348 KB | Output is correct |
5 | Correct | 0 ms | 348 KB | Output is correct |
6 | Correct | 0 ms | 344 KB | Output is correct |
7 | Correct | 1 ms | 348 KB | Output is correct |
8 | Correct | 0 ms | 348 KB | Output is correct |
9 | Correct | 1 ms | 348 KB | Output is correct |
10 | Correct | 0 ms | 348 KB | Output is correct |
11 | Correct | 950 ms | 432 KB | Output is correct |
12 | Correct | 950 ms | 456 KB | Output is correct |
13 | Correct | 950 ms | 596 KB | Output is correct |
14 | Correct | 950 ms | 468 KB | Output is correct |
15 | Correct | 949 ms | 448 KB | Output is correct |
16 | Correct | 950 ms | 452 KB | Output is correct |
17 | Correct | 950 ms | 600 KB | Output is correct |
18 | Correct | 950 ms | 448 KB | Output is correct |
19 | Correct | 950 ms | 452 KB | Output is correct |
20 | Correct | 950 ms | 448 KB | Output is correct |
21 | Correct | 950 ms | 432 KB | Output is correct |
22 | Correct | 950 ms | 600 KB | Output is correct |
23 | Correct | 950 ms | 432 KB | Output is correct |
24 | Correct | 950 ms | 428 KB | Output is correct |
25 | Correct | 950 ms | 596 KB | Output is correct |
26 | Correct | 950 ms | 432 KB | Output is correct |
27 | Correct | 950 ms | 440 KB | Output is correct |
28 | Correct | 950 ms | 432 KB | Output is correct |
29 | Correct | 950 ms | 432 KB | Output is correct |
30 | Correct | 950 ms | 600 KB | Output is correct |
31 | Correct | 950 ms | 596 KB | Output is correct |
32 | Correct | 949 ms | 592 KB | Output is correct |
33 | Correct | 950 ms | 428 KB | Output is correct |
34 | Correct | 950 ms | 592 KB | Output is correct |
35 | Correct | 950 ms | 596 KB | Output is correct |
36 | Correct | 950 ms | 432 KB | Output is correct |
37 | Correct | 949 ms | 596 KB | Output is correct |
38 | Correct | 949 ms | 436 KB | Output is correct |
39 | Correct | 950 ms | 428 KB | Output is correct |
40 | Correct | 950 ms | 444 KB | Output is correct |
41 | Correct | 950 ms | 348 KB | Output is correct |
42 | Correct | 950 ms | 432 KB | Output is correct |
43 | Correct | 950 ms | 592 KB | Output is correct |
44 | Correct | 950 ms | 348 KB | Output is correct |
45 | Correct | 950 ms | 348 KB | Output is correct |
46 | Correct | 950 ms | 592 KB | Output is correct |
47 | Correct | 950 ms | 428 KB | Output is correct |
48 | Correct | 950 ms | 592 KB | Output is correct |
49 | Correct | 949 ms | 348 KB | Output is correct |
50 | Correct | 950 ms | 432 KB | Output is correct |
51 | Correct | 950 ms | 432 KB | Output is correct |
52 | Correct | 950 ms | 428 KB | Output is correct |
53 | Correct | 949 ms | 436 KB | Output is correct |
54 | Correct | 950 ms | 444 KB | Output is correct |
55 | Correct | 949 ms | 596 KB | Output is correct |
56 | Correct | 950 ms | 432 KB | Output is correct |
57 | Correct | 950 ms | 592 KB | Output is correct |
58 | Correct | 950 ms | 348 KB | Output is correct |
59 | Correct | 949 ms | 432 KB | Output is correct |
60 | Correct | 950 ms | 428 KB | Output is correct |
61 | Correct | 950 ms | 436 KB | Output is correct |
62 | Correct | 949 ms | 344 KB | Output is correct |
63 | Correct | 950 ms | 592 KB | Output is correct |
64 | Correct | 950 ms | 344 KB | Output is correct |
65 | Correct | 950 ms | 452 KB | Output is correct |
66 | Correct | 950 ms | 348 KB | Output is correct |
67 | Correct | 950 ms | 436 KB | Output is correct |
68 | Correct | 950 ms | 432 KB | Output is correct |
69 | Correct | 950 ms | 436 KB | Output is correct |
70 | Correct | 949 ms | 440 KB | Output is correct |
71 | Correct | 949 ms | 592 KB | Output is correct |
72 | Correct | 950 ms | 432 KB | Output is correct |
73 | Correct | 950 ms | 596 KB | Output is correct |
74 | Correct | 950 ms | 432 KB | Output is correct |
75 | Correct | 950 ms | 436 KB | Output is correct |
76 | Correct | 949 ms | 436 KB | Output is correct |
77 | Correct | 950 ms | 436 KB | Output is correct |
78 | Correct | 950 ms | 592 KB | Output is correct |
79 | Correct | 950 ms | 440 KB | Output is correct |
80 | Correct | 950 ms | 596 KB | Output is correct |
81 | Correct | 950 ms | 448 KB | Output is correct |
82 | Correct | 950 ms | 348 KB | Output is correct |
83 | Correct | 950 ms | 448 KB | Output is correct |
84 | Correct | 951 ms | 448 KB | Output is correct |
85 | Correct | 950 ms | 448 KB | Output is correct |
86 | Correct | 950 ms | 452 KB | Output is correct |
87 | Correct | 950 ms | 452 KB | Output is correct |
88 | Correct | 950 ms | 448 KB | Output is correct |
89 | Correct | 950 ms | 456 KB | Output is correct |
90 | Correct | 950 ms | 456 KB | Output is correct |
91 | Correct | 950 ms | 452 KB | Output is correct |
92 | Correct | 950 ms | 452 KB | Output is correct |
93 | Correct | 950 ms | 348 KB | Output is correct |
94 | Correct | 950 ms | 456 KB | Output is correct |
95 | Correct | 950 ms | 452 KB | Output is correct |
96 | Correct | 951 ms | 448 KB | Output is correct |
97 | Incorrect | 950 ms | 452 KB | Output isn't correct |
98 | Halted | 0 ms | 0 KB | - |