結果
| 問題 |
No.281 門松と魔法(1)
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-10-29 05:46:37 |
| 言語 | Crystal (1.14.0) |
| 結果 |
CE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 661 bytes |
| コンパイル時間 | 1,098 ms |
| コンパイル使用メモリ | 218,400 KB |
| 最終ジャッジ日時 | 2024-11-14 19:22:53 |
| 合計ジャッジ時間 | 1,655 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
[2mShowing last frame. Use --error-trace for full trace.[0m
In [4mMain.cr:16:9[0m
[2m 16 | [0m[1mrescue DivisionByZero[0m
[32;1m^-------------[0m
[33;1mError: undefined constant DivisionByZero[0m
ソースコード
#!/usr/bin/env crystal
def solve_short(d,a,b,c)
begin
r=0
if a==c
c=[0,c-d].max
r+=1
end
t=b-[a,c].min+1
if t>0
cnt=(t+d-1)/d
r+=cnt
b=[0,b-r*d].max
end
a==b || b==c ? -1 : r
rescue DivisionByZero
-1
end
end
def solve_tall(d,a,b,c)
begin
r=0
t=a-b+1
if t>0
cnt=(t+d-1)/d
r+=cnt
a=[0,a-cnt*d].max
end
t=c-b+1
if t>0
cnt=(t+d-1)/d
r+=cnt
c=[0,c-cnt*d].max
end
if a==c
c=[0,c-d].max
r+=1
end
a==b || b==c || c==a ? -1 : r
rescue DivisionByZero
-1
end
end
d,a,b,c=4.times.map{gets.not_nil!.to_i}.to_a
x=solve_short(d,a,b,c)
y=solve_tall(d,a,b,c)
p x>=0&&y>=0 ? [x,y].min : [x,y].max