PAT乙級(Basic Level)真題-1014 科學計數法 (20)
阿新 • • 發佈:2019-01-25
科學計數法 (20)
時間限制 1000 ms 記憶體限制 32768 KB 程式碼長度限制 100 KB 判斷程式 Standard (來自 小小)題目描述
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式[+-][1-9]"."[0-9]+E[+-][0-9]+,即數字的整數部分 只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。 現以科學計數法的格式給出實數A,請編寫程式按普通數字表示法輸出A,並保證所有有效位都被保留。
輸入描述:
每個輸入包含1個測試用例,即一個以科學計數法表示的實數A。該數字的儲存長度不超過9999位元組,且其指數的絕對值不超過9999。
輸出描述:
對每個測試用例,在一行中按普通數字表示法輸出A,並保證所有有效位都被保留,包括末尾的0。
輸入例子:
+1.23400E-03
輸出例子:
0.00123400
#include <cstdio> #include <cstring> #include <cmath> #include <iostream> #include <algorithm> #include <string> #include <cstdlib> #include <stack> #include <map> #include <set> #include <queue> using namespace std; const int maxn = 1e5+100; char s[maxn]; int main(void) { cin>>s; int flag=0; int len = strlen(s); if(s[0]=='+') flag=1; int num2=0; int p=0; int mark_E=0; for(int i=0;i<len;i++) { if(s[i]=='E') { mark_E=i; if(s[i+1]=='+') p=1; for(int j=i+2;j<len;j++) num2=num2*10+s[j]-'0'; break; } } if(flag==0) printf("-"); if(num2==0) { for(int i=1;i<mark_E;i++) printf("%c",s[i]); return 0; } if(p==1)//+ { int cnt=0,i; printf("%c",s[1]); for(i=3;i<mark_E;i++) { printf("%c",s[i]); cnt++; if(cnt==num2) { printf("."); continue; } } for(;cnt<num2;cnt++) printf("0"); } else //- { int cnt=1,i; printf("0."); for(int i=1;i<num2;i++) printf("0"); for(i=1;i<mark_E;i++) { if(s[i]=='.') continue; printf("%c",s[i]); } } puts(""); return 0; }