結果
問題 |
No.405 ローマ数字の腕時計
|
ユーザー |
![]() |
提出日時 | 2016-08-07 20:39:19 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 665 bytes |
コンパイル時間 | 400 ms |
コンパイル使用メモリ | 57,068 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-07-06 19:01:50 |
合計ジャッジ時間 | 1,133 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 27 |
ソースコード
#include<iostream> #include<string> using namespace std; int convert(string s) { if (s == "IX")return 9; int ret = 0; for (int i = 0; i < s.length(); i++) { if (s[i] == 'I') ret += 1; if (s[i] == 'V') ret += 5; if (s[i] == 'X') ret += 10; } return ret; } string convert(int x) { if (x == 9)return "IX"; string s = ""; while (x > 0) { if (x >= 10) { s += "X"; x = x - 10; } if (x >= 5) { s += "V"; x = x - 5; } if (x >= 1) { s += "I"; x = x - 1; } } return s; } int main() { string s; int n; cin >> s >> n; int s2 = ((convert(s) + n)%12+12)%12; if (s2 == 0)s2 = 12; cout << convert(s2) << endl; return 0; }