結果
| 問題 |
No.518 ローマ数字の和
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-05-29 18:18:15 |
| 言語 | Ruby (3.4.1) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 553 bytes |
| コンパイル時間 | 63 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 12,416 KB |
| 最終ジャッジ日時 | 2024-09-21 18:10:10 |
| 合計ジャッジ時間 | 2,587 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | RE * 3 |
| other | RE * 19 |
コンパイルメッセージ
Syntax OK
ソースコード
def checkio(data) ['','M','MM','MMM'][data/1000]+['','C','CC','CCC','CD','D','DC','DCC','DCCC','CM'][data/100%10]+['','X','XX','XXX','XL','L','LX','LXX','LXXX','XC'][data/10%10]+['','I','II','III','IV','V','VI','VII','VIII','IX'][data%10] end
def tonum(roman)
m={'I':1,'V':5,'X':10,'L':50,'C':100,'D':500,'M':1000}
r=0
roman.size.times{|i|r+=m[roman[i]]*(if i==roman.size-1 or m[roman[i]]>=m[roman[i+1]] then 1 else -1 end)}
return r
end
gets
n=gets.split.map{|e|tonum(e)}.reduce(:+)
if n>3999
puts :ERROR
else
p checkio(n)
end