結果
| 問題 | 
                            No.518 ローマ数字の和
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2017-05-29 18:19:35 | 
| 言語 | Ruby  (3.4.1)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 84 ms / 2,000 ms | 
| コード長 | 563 bytes | 
| コンパイル時間 | 78 ms | 
| コンパイル使用メモリ | 7,680 KB | 
| 実行使用メモリ | 12,288 KB | 
| 最終ジャッジ日時 | 2024-09-21 18:10:14 | 
| 合計ジャッジ時間 | 2,553 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 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
    puts checkio(n)
end