結果
問題 |
No.405 ローマ数字の腕時計
|
ユーザー |
|
提出日時 | 2022-05-24 20:17:03 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 1,443 bytes |
コンパイル時間 | 956 ms |
コンパイル使用メモリ | 101,008 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-06 19:35:06 |
合計ジャッジ時間 | 1,737 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 27 |
ソースコード
#define _USE_MATH_DEFINES #include <iostream> //cin, cout #include <vector> //vector #include <algorithm> //sort,min,max,count #include <string> //string,getline, to_string #include <cstdlib> //abs(int) #include <utility> //swap, pair #include <deque> //deque #include <climits> //INT_MAX #include <bitset> //bitset #include <cmath> //sqrt, ceil. M_PI, pow, sin #include <ios> //fixed #include <iomanip> //setprecision #include <sstream> //stringstream #include <numeric> //gcd, assumlate #include <random> //randam_device #include <limits> //numeric_limits using namespace std; constexpr long long int D_MOD = 1000000007; inline int RomanToArabic(const string A) { //ローマ数字をアラビア数字に変換(1~12),4は'IIII' vector<string> R = { "I","II","III","IIII","V","VI","VII","VIII","IX","X","XI","XII" }; int i = 0; for (; i < 12; i++) { if (R[i] == A) { return(i + 1); } } return(0); } inline string ArabicToRoman(const int A) { //アラビア数字をローマ数字に変換(1~12),4は'IIII' vector<string> R = { "I","II","III","IIII","V","VI","VII","VIII","IX","X","XI","XII" }; if (1 <= A && A <= 12) { return (R[A - 1]); } else { return("False"); } } int main() { string S1; cin >> S1; int a = RomanToArabic(S1); int T; cin >> T; a = a + T; a = a % 12; if (a < 0) { a = a + 12; } if (a == 0) { a = 12; } cout << ArabicToRoman(a) << endl; return 0; }