PAT乙級1024(C語言)-科學計數法 (20)
阿新 • • 發佈:2019-01-09
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式[+-][1-9]"."[0-9]+E[+-][0-9]+,即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。
現以科學計數法的格式給出實數A,請編寫程式按普通數字表示法輸出A,並保證所有有效位都被保留。
輸入格式:
每個輸入包含1個測試用例,即一個以科學計數法表示的實數A。該數字的儲存長度不超過9999位元組,且其指數的絕對值不超過9999。
輸出格式:
對每個測試用例,在一行中按普通數字表示法輸出A,並保證所有有效位都被保留,包括末尾的0。
輸入樣例1:+1.23400E-03
0.00123400輸入樣例2:
-1.2E+10輸出樣例2:
-12000000000
#include<bits/stdc++.h> using namespace std; int main(void) { char head,a[10001]= {0}; int ex=0; scanf("%c%c.%[0-9]E%d",&head,&a[0],a+1,&ex);//輸入拆分 if (head == '-') printf("-"); if(ex>=0) { for(int i=0; i<ex+1||a[i]!=0; i++) { if(i==ex+1) printf("."); printf("%c",a[i]==0?'0':a[i]); } } else { printf("0."); for(int i=1; i<(-ex); i++) printf("0"); printf("%s",a); } printf("\n"); return 0; }