結果

問題 No.518 ローマ数字の和
ユーザー koba-e964
提出日時 2017-07-22 21:21:20
言語 Ruby
(3.4.1)
結果
AC  
実行時間 103 ms / 2,000 ms
コード長 970 bytes
コンパイル時間 46 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-10-09 10:01:21
合計ジャッジ時間 3,208 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 19
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
プレゼンテーションモードにする

def one_level(dig, pat)
if dig == 9
return pat[0] + pat[2]
end
if dig == 4
return pat[0] + pat[1]
end
if dig >= 5
return pat[1] + pat[0] * (dig - 5)
end
return pat[0] * dig
end
def number_to_roman(num)
ret = 'M' * (num / 1000)
num -= num / 1000 * 1000
for v, pat in [[100, 'CDM'], [10, 'XLC'], [1, 'IVX']]
dig = num / v
num -= dig * v
ret += one_level(dig, pat)
end
ret
end
def roman_to_number(str)
val = 0
dict = {'IV' => -2, 'IX' => -2, 'XL' => -20, 'XC' => -20, 'CD' => -200,
'CM' => -200}
for pat, diff in dict
if str.include?(pat)
val += diff
end
end
dict = {'I' => 1, 'V' => 5, 'X' => 10, 'L' => 50, 'C' => 100,
'D' => 500, 'M' => 1000}
for letter, diff in dict
val += diff * str.count(letter)
end
val
end
_ = gets.to_i
r = gets.chomp.split
sum = 0
for v in r
sum += roman_to_number(v)
end
if sum >= 4000
puts "ERROR"
else
puts number_to_roman(sum)
end
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0