結果
問題 | No.2385 Parse Integer with Radix |
ユーザー | kotatsugame |
提出日時 | 2023-07-21 21:24:05 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 588 bytes |
コンパイル時間 | 572 ms |
コンパイル使用メモリ | 66,536 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-21 22:37:38 |
合計ジャッジ時間 | 1,007 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 11 |
ソースコード
#include<iostream> #include<cassert> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int Q;cin>>Q; for(;Q--;) { string S;cin>>S; long ans=0; if(S.size()==1)ans=S[0]-'0'; else if(S[1]=='b') {//2 for(int i=2;i<S.size();i++)ans=ans*2+(S[i]-'0'); } else if(S[1]=='o') {//8 for(int i=2;i<S.size();i++)ans=ans*8+(S[i]-'0'); } else if(S[1]=='x') {//16 for(int i=2;i<S.size();i++)ans=ans*16+(S[i]-'0'<=9?S[i]-'0':S[i]-'a'+10); } else {//10 for(int i=0;i<S.size();i++)ans=ans*10+(S[i]-'0'); } cout<<ans<<endl; } }