結果
問題 |
No.707 書道
|
ユーザー |
![]() |
提出日時 | 2019-12-20 13:26:55 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 292 ms / 2,000 ms |
コード長 | 567 bytes |
コンパイル時間 | 185 ms |
コンパイル使用メモリ | 7,424 KB |
実行使用メモリ | 12,416 KB |
最終ジャッジ日時 | 2024-07-08 07:40:36 |
合計ジャッジ時間 | 1,893 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 6 |
コンパイルメッセージ
Syntax OK
ソースコード
def min(a,b); a < b ? a : b; end H,W = gets.split.map(&:to_i) P = H.times.map{ gets.chomp } def cost(x0, y0) s = 0.0 (1 .. W).each do |x| (1 .. H).each do |y| x2 = (x - x0).abs ** 2 y2 = (y - y0).abs ** 2 s += Math.sqrt(x2 + y2) if P[y-1][x-1] == '1' end end return s end cost_min = Float::INFINITY [0, W + 1].each do |x0| (1 .. H).each do |y0| cost_min = min(cost_min, cost(x0, y0)) end end [0, H + 1].each do |y0| (1 .. W).each do |x0| cost_min = min(cost_min, cost(x0, y0)) end end puts "%.8f" % cost_min