題目信息
科學(xué)計(jì)數(shù)法是科學(xué)家用來(lái)表示很大或很小的數(shù)字的一種方便的方法,其滿足正則表達(dá)式[+-][1-9]"."[0-9]+E[+-][0-9]+,即數(shù)字的整數(shù)部分只有1位,小數(shù)部分至少有1位,該數(shù)字及其指數(shù)部分的正負(fù)號(hào)即使對(duì)正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù)A,請(qǐng)編寫程序按普通數(shù)字表示法輸出A,并保證所有有效位都被保留。
輸入格式:
每個(gè)輸入包含1個(gè)測(cè)試用例,即一個(gè)以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù)A。該數(shù)字的存儲(chǔ)長(zhǎng)度不超過(guò)9999字節(jié),且其指數(shù)的絕對(duì)值不超過(guò)9999。
輸出格式:
對(duì)每個(gè)測(cè)試用例,在一行中按普通數(shù)字表示法輸出A,并保證所有有效位都被保留,包括末尾的0。
輸入樣例1:
+1.23400E-03
輸出樣例1:
0.00123400
輸入樣例2:
-1.2E+10
輸出樣例2:
-12000000000
代碼
#include<iostream>
using namespace std;
int main(){
string s;int i=0,e=0,pos;
cin >> s;
while(s[i]!='E'){i++;}
pos=i;//pos為E的位置
i+=2;//i++是指數(shù)的正負(fù)號(hào)的位置
while(i<s.length()){e=e*10+s[i]-'0';i++;}//e的絕對(duì)值
if(s[0]=='-') printf("-");//第一位若為負(fù)號(hào)則輸出,正好則省略
if(s[pos+1]=='-'){//如果指數(shù)為負(fù)數(shù)
printf("0.");e--;
for(i=0;i<e;i++) printf("0");
printf("%c",s[1]);
for(i=3;i<pos;i++) printf("%c",s[i]);
}else{ //如果指數(shù)為正數(shù)
printf("%c",s[1]);
if(e>=pos-3){
for(i=3;i<pos;i++) printf("%c",s[i]);
for(int i=0;i<e-pos+3;i++) printf("0");
}else{
for(i=3;i<3+e;i++) printf("%c",s[i]);
printf(".");
for(i=3+e;i<pos;i++) printf("%c",s[i]);
}
}
return 0;
}
測(cè)試結(jié)果

image.png