結果

問題 No.707 書道
ユーザー nominomi
提出日時 2018-06-30 07:50:46
言語 C++14
(gcc 13.2.0 + boost 1.83.0)
結果
AC  
実行時間 7 ms / 2,000 ms
コード長 2,182 bytes
コンパイル時間 1,450 ms
コンパイル使用メモリ 164,896 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-13 16:11:20
合計ジャッジ時間 1,989 ms
ジャッジサーバーID
(参考情報)
judge13 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,376 KB
testcase_01 AC 2 ms
4,380 KB
testcase_02 AC 3 ms
4,376 KB
testcase_03 AC 1 ms
4,376 KB
testcase_04 AC 1 ms
4,376 KB
testcase_05 AC 4 ms
4,376 KB
testcase_06 AC 5 ms
4,380 KB
testcase_07 AC 7 ms
4,380 KB
testcase_08 AC 2 ms
4,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

#define ll long long
#define vvi vector<vector<int>>
#define vec vector
#define pq priority_queue
#define all(v) (v).begin(), (v).end()
#define uniqueV(x) sort(x.begin(), x.end()); x.erase(unique(x.begin(), x.end()), x.end());
#define rep(i, n) for (int (i) = (0); (i) < (n); ++(i))
#define repp(i, m, n) for (int (i) = (m); (i) < (n); ++(i))
#define dbg(x) cerr << #x << ": " << x << endl;
#define dbg2(x, y) cerr<<"("<<#x<<", "<<#y<<") = "<<"("<<x<<", "<<y<<")"<<endl;
#define dbg3(x, y, z) cerr<<"("<<#x<<", "<<#y<<", "<<#z<<") = "<<"("<<x<<", "<<y<<", "<<z<<")"<<endl;
#define dbgB(value, size) cerr<<#value<<": "<<bitset<size>(value) << endl;
#define line() cerr << "---------------" << endl;

const int dx[] = {1, -1, 0, 0};
const int dy[] = {0, 0, -1, 1};
const double PI = 3.14159265358979323846;

template<class T>bool chmax(T &a, const T &b) { if (a<b) { a = b; return 1; } return 0; }
template<class T>bool chmin(T &a, const T &b) { if (b<a) { a = b; return 1; } return 0; }

template<typename T>
void printA(vector<T> &printArray, char between = ' ') {
   int paSize = printArray.size();
   for (int i = 0; i < paSize; i++) { cerr << printArray[i] << between;}
   if (between != '\n') {cerr << endl;}
}

// ------------------------------------------------------------------------------------------

int H, W;
int B[111][111];

void print() {
   for (int i = 0; i <= H+1; i++) {
      for (int j = 0; j <= W+1; j++) {
         cout << B[i][j];
      }
      cout << endl;
   }
}

double calc(int x, int y) {
   double ret = 0;
   for (int i = 1; i <= H; i++) {
      for (int j = 1; j <= W; j++) {
         if (B[i][j]) ret += hypot(y-i, x-j);
      }
   }
   return ret;
}

int main() {
   cin >> H >> W;
   rep (i, H) {
      string s; cin >> s;
      rep (j, W) {
         B[i+1][j+1] = s[j] - '0';
      }
   }

   double ans = 1e8;
   for (int y = 1; y <= H; y++) { chmin(ans, calc(0, y)); }
   for (int y = 1; y <= H; y++) { chmin(ans, calc(W+1, y)); }
   for (int x = 1; x <= W; x++) { chmin(ans, calc(x, 0)); }
   for (int x = 1; x <= W; x++) { chmin(ans, calc(x, H+1)); }

   printf("%.10f\n", ans);

   return 0;
}
0