結果
問題 |
No.2385 Parse Integer with Radix
|
ユーザー |
![]() |
提出日時 | 2023-07-21 21:32:54 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 2,000 ms |
コード長 | 1,049 bytes |
コンパイル時間 | 579 ms |
コンパイル使用メモリ | 68,484 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-21 22:51:30 |
合計ジャッジ時間 | 1,173 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 11 |
ソースコード
#include<iostream> #include<vector> using namespace std; int main( void ) { int Q; cin >> Q; string S; while( Q-- > 0 ) { cin >> S; if( S.size() == 1 || ( '0' <= S[1] && S[1] <= '9' ) ) { cout << S << endl; } else { long long ans = 0; long long base, cur; if( S[1] == 'b' ) { base = 2; } else if( S[1] == 'o' ) { base = 8; } else { base = 16; } cur = 1; for( int i = S.size() - 1; i > 1; i-- ) { if( '0' <= S[i] && S[i] <= '9' ) { ans += cur * ( S[i] - '0' ); } else { ans += cur * ( S[i] - 'a' + 10 ); } cur *= base; } cout << ans << endl; } } return 0; }