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
AC × 3
AC × 47
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