PAT_B_1024 科學計數法 (20 分)
阿新 • • 發佈:2019-01-11
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式 [+-][1-9].
[0-9]+E[+-][0-9]+,即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。
現以科學計數法的格式給出實數 A,請編寫程式按普通數字表示法輸出 A,並保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即一個以科學計數法表示的實數 A。該數字的儲存長度不超過 9999 位元組,且其指數的絕對值不超過 9999。
輸出格式:
對每個測試用例,在一行中按普通數字表示法輸出 A,並保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400E-03
輸出樣例 1:
0.00123400
輸入樣例 2:
-1.2E+10
輸出樣例 2:
-12000000000
#include <iostream> #include <math.h> #include <string.h> using namespace std; int main() { char inchar[10000]; cin>>inchar; int i=3; while(inchar[i]!='E'){ i++; } int flag=++i; //指數符號位 int weishu=strlen(inchar)-flag-1; int zhishu=0; while(true){ ++i; if(i<strlen(inchar)){ zhishu+=(inchar[i]-'0')*pow(10,weishu-1); weishu--; } else break; } if(inchar[0]=='-') cout<<"-"; if(inchar[flag]=='+') { cout<<inchar[1]; for(int i=3;i<flag-1;i++) { if(zhishu==0) cout<<"."; cout<<inchar[i]; zhishu--; } if(zhishu>0) { while(zhishu--) { cout<<"0"; } } } if(inchar[flag]=='-') { if(zhishu>0) { cout<<"0."; zhishu--; while(zhishu--) { cout<<"0"; } cout<<inchar[1]; for(int i=3;i<flag-1;i++) { cout<<inchar[i]; } } } cout<<endl; return 0; }