Submission #1545950
Source Code Expand
#include <bits/stdc++.h> #define FOR(i, a, b) for (int i = (a); i < (b); i++) #define FORd(i, a, b) for (int i = (a); i >= (b); i--) #define REP(i, n) FOR(i, 0, n) #define TRACE(x) cout << #x << " = " << x << "\n" #define _ << " _ " << #define ll long long #define pii pair <int, int> #define ld long double using namespace std; ld fontana = (((ld) 20.0 * (ld) 3.141592653589793238462643383279) / (ld) 4.0); vector <pii> ve; bool flag; bool cmp(pii a, pii b) { if (flag) return a.first > b.first; return a.first < b.first; } unordered_map <int, int> loga; void add(int x, int v) { for (x; x <= 1e8; x += x & -x) { loga[x] = max(loga[x], v); } return; } int val(int x) { int tr = 0; for (x; x; x -= x & -x) { tr = max(tr, loga[x]); } return tr; } int main() { ios_base::sync_with_stdio(false); int x1, y1, x2, y2; cin >> x1 >> y1 >> x2 >> y2; x1++; y1++; x2++; y2++; if (x1 > x2) { swap(x1, x2); swap(y1, y2); } if (y1 > y2) flag = 1; int n; cin >> n; REP(i, n) { int x, y; cin >> x >> y; x++; y++; if (x < min(x1, x2) || x > max(x1, x2)) continue; if (y < min(y1, y2) || y > max(y1, y2)) continue; ve.push_back({x, y}); } sort(ve.begin(), ve.end(), cmp); ld out = ((ld)(abs(x2 - x1)) * (ld) 100) + ((ld)(abs(y2 - y1)) * (ld) 100); int ma = 0; REP(i, ve.size()) { int x = ve[i].first; int y = ve[i].second; int tr = val(y); ma = max(ma, tr + 1); add(y, tr + 1); } out -= (ld) ma * (ld) 20; out += (ld) ma * fontana; if (ma > min(abs(x2 - x1), abs(y2 - y1))) { out += fontana; } cout << fixed << setprecision(15) << out << "\n"; return 0; }
Submission Info
Submission Time | |
---|---|
Task | C - Fountain Walk |
User | dfistric |
Language | C++14 (GCC 5.4.1) |
Score | 900 |
Code Size | 1771 Byte |
Status | AC |
Exec Time | 753 ms |
Memory | 69240 KB |
Judge Result
Set Name | Sample | All | ||||
---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 900 / 900 | ||||
Status |
|
|
Set Name | Test Cases |
---|---|
Sample | sample_01.txt, sample_02.txt, sample_03.txt |
All | sample_01.txt, sample_02.txt, sample_03.txt, sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_1_26.txt, subtask_1_27.txt, subtask_1_28.txt, subtask_1_29.txt, subtask_1_30.txt, subtask_1_31.txt, subtask_1_32.txt, subtask_1_33.txt, subtask_1_34.txt, subtask_1_35.txt, subtask_1_36.txt, subtask_1_37.txt, subtask_1_38.txt, subtask_1_39.txt, subtask_1_40.txt, subtask_1_41.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
sample_01.txt | AC | 1 ms | 256 KB |
sample_02.txt | AC | 1 ms | 256 KB |
sample_03.txt | AC | 1 ms | 256 KB |
subtask_1_01.txt | AC | 1 ms | 256 KB |
subtask_1_02.txt | AC | 1 ms | 256 KB |
subtask_1_03.txt | AC | 1 ms | 256 KB |
subtask_1_04.txt | AC | 1 ms | 256 KB |
subtask_1_05.txt | AC | 1 ms | 256 KB |
subtask_1_06.txt | AC | 1 ms | 256 KB |
subtask_1_07.txt | AC | 1 ms | 256 KB |
subtask_1_08.txt | AC | 1 ms | 256 KB |
subtask_1_09.txt | AC | 14 ms | 256 KB |
subtask_1_10.txt | AC | 30 ms | 256 KB |
subtask_1_11.txt | AC | 8 ms | 256 KB |
subtask_1_12.txt | AC | 609 ms | 69240 KB |
subtask_1_13.txt | AC | 31 ms | 256 KB |
subtask_1_14.txt | AC | 15 ms | 256 KB |
subtask_1_15.txt | AC | 8 ms | 256 KB |
subtask_1_16.txt | AC | 195 ms | 10096 KB |
subtask_1_17.txt | AC | 25 ms | 256 KB |
subtask_1_18.txt | AC | 20 ms | 256 KB |
subtask_1_19.txt | AC | 21 ms | 384 KB |
subtask_1_20.txt | AC | 198 ms | 10096 KB |
subtask_1_21.txt | AC | 589 ms | 69240 KB |
subtask_1_22.txt | AC | 187 ms | 10096 KB |
subtask_1_23.txt | AC | 585 ms | 69240 KB |
subtask_1_24.txt | AC | 1 ms | 256 KB |
subtask_1_25.txt | AC | 1 ms | 256 KB |
subtask_1_26.txt | AC | 1 ms | 256 KB |
subtask_1_27.txt | AC | 1 ms | 256 KB |
subtask_1_28.txt | AC | 43 ms | 768 KB |
subtask_1_29.txt | AC | 52 ms | 2572 KB |
subtask_1_30.txt | AC | 703 ms | 69240 KB |
subtask_1_31.txt | AC | 189 ms | 10096 KB |
subtask_1_32.txt | AC | 191 ms | 10096 KB |
subtask_1_33.txt | AC | 189 ms | 10096 KB |
subtask_1_34.txt | AC | 191 ms | 10096 KB |
subtask_1_35.txt | AC | 583 ms | 69240 KB |
subtask_1_36.txt | AC | 753 ms | 69240 KB |
subtask_1_37.txt | AC | 599 ms | 69240 KB |
subtask_1_38.txt | AC | 608 ms | 69240 KB |
subtask_1_39.txt | AC | 589 ms | 69240 KB |
subtask_1_40.txt | AC | 587 ms | 69240 KB |
subtask_1_41.txt | AC | 583 ms | 69240 KB |