Submission #468793


Source Code Expand

#include <iostream>
#include <cstdio>
#include <cmath>
#include <vector>
#include <queue>

#include <map>
#include <set>
#include <string>
#include <algorithm>
#include <functional>
using namespace std;
#define FOR(i,a,b) for (int i=(a);i<(b);i++)
#define RFOR(i,a,b) for (int i=(b)-1;i>=(a);i--)
#define REP(i,n) for (int i=0;i<(n);i++)
#define RREP(i,n) for (int i=(n)-1;i>=0;i--)
#define INF 1<<30
#define MP make_pair
#define mp make_pair
#define pb push_back
#define PB push_back
#define DEBUG(x) cout<<#x<<": "<<x<<endl
#define ll long long
#define ull unsigned long long

int main(){
    cin.tie(0);
    ios::sync_with_stdio(false);

    int x, y, n;
    cin >> x >> y >> n;

    double res = 300.0;

    int tx[n], ty[n];
    REP(i, n) {
        cin >> tx[i];
        cin >> ty[i];
    }

    REP(i, n) {
        int tx1, ty1, tx2, ty2;
        int cx, cy;

        tx1 = tx[i]; ty1 = ty[i];
        if(i < n-1) {
            tx2 = tx[i+1]; ty2 = ty[i+1];
        } else {
            tx2 = tx[0]; ty2 = ty[0];
        }
        cx = x; cy = y;

        // y - y1 = ((y2 - y1) / (x2 - x1)) * (x - x1)
        // (y1 - y2) x + (x2 - x1) y - y1 * (x2 - x1) + x1 * (y2 - y1) = 0
        // (y1 - y2) x + (x2 - x1) y - y1 * x2 + x1 * y2= 0
        double a = ty1 - ty2;
        double b = tx2 - tx1;
        double c = -(tx2 * ty1) + tx1 * ty2;
        double cres = fabs(a * cx + b * cy + c) / sqrt(a * a + b * b);

        res = min(res, cres);
    }

    cout.precision(10);
    cout << res << endl;
    return 0;
}

Submission Info

Submission Time
Task B - アリの高橋くん
User yumechi
Language C++11 (GCC 4.9.2)
Score 100
Code Size 1590 Byte
Status AC
Exec Time 27 ms
Memory 932 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 100 / 100
Status
AC × 3
AC × 33
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, subtask1_00.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt
Case Name Status Exec Time Memory
sample_01.txt AC 27 ms 800 KB
sample_02.txt AC 26 ms 932 KB
sample_03.txt AC 27 ms 804 KB
subtask1_00.txt AC 27 ms 916 KB
subtask1_01.txt AC 25 ms 924 KB
subtask1_02.txt AC 26 ms 928 KB
subtask1_03.txt AC 26 ms 924 KB
subtask1_04.txt AC 26 ms 924 KB
subtask1_05.txt AC 25 ms 928 KB
subtask1_06.txt AC 26 ms 924 KB
subtask1_07.txt AC 26 ms 924 KB
subtask1_08.txt AC 27 ms 796 KB
subtask1_09.txt AC 26 ms 920 KB
subtask1_10.txt AC 26 ms 924 KB
subtask1_11.txt AC 26 ms 844 KB
subtask1_12.txt AC 24 ms 928 KB
subtask1_13.txt AC 25 ms 932 KB
subtask1_14.txt AC 25 ms 920 KB
subtask1_15.txt AC 26 ms 928 KB
subtask1_16.txt AC 26 ms 932 KB
subtask1_17.txt AC 25 ms 924 KB
subtask1_18.txt AC 25 ms 932 KB
subtask1_19.txt AC 25 ms 924 KB
subtask1_20.txt AC 25 ms 932 KB
subtask1_21.txt AC 25 ms 932 KB
subtask1_22.txt AC 25 ms 932 KB
subtask1_23.txt AC 26 ms 804 KB
subtask1_24.txt AC 26 ms 920 KB
subtask1_25.txt AC 26 ms 924 KB
subtask1_26.txt AC 26 ms 920 KB
subtask1_27.txt AC 26 ms 920 KB
subtask1_28.txt AC 26 ms 920 KB
subtask1_29.txt AC 25 ms 912 KB