結果

問題 No.1447 Greedy MtSaka
コンテスト
ユーザー butsurizuki
提出日時 2021-03-30 02:35:03
言語 C++17(gcc12)
(gcc 12.4.0 + boost 1.89.0)
コンパイル:
g++-12 -O2 -lm -std=c++17 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 786 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 6,903 ms
コンパイル使用メモリ 336,468 KB
実行使用メモリ 6,400 KB
最終ジャッジ日時 2026-06-19 02:06:42
合計ジャッジ時間 8,263 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 17
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include<bits/stdc++.h>
#include "testlib.h"

using namespace std;
using pi=pair<int,int>;

int cp(pi a,pi b){
  return a.first*b.second-a.second*b.first;
}

pi vm(pi a,pi b){
  return make_pair(a.first-b.first,a.second-b.second);
}

int main(int argc, char* argv[]){
  registerValidation(argc, argv);
  int n=inf.readInt(3,30);inf.readEoln();
  vector<pi> vp(n);
  for(int i=0;i<n;i++){
    vp[i].first=inf.readInt(-10000,10000);inf.readSpace();
    vp[i].second=inf.readInt(-10000,10000);inf.readEoln();
  }
  for(int i=0;i<n;i++){
    ensuref(cp(vm(vp[(i+1)%n],vp[i]),vm(vp[(i+2)%n],vp[(i+1)%n]))>0,"the points aren't clockwise");
  }
  int res=0;
  for(int i=2;i<n;i++){
    res+=abs(cp(vm(vp[i-1],vp[0]),vm(vp[i],vp[0])));
  }
  cout << res << '\n';
  inf.readEof();
  return 0;
}
0