題目
科學計數法是科學家用來表示很大或很小的數字的一種友善的方法,其滿足正規表達式 [±][1-9].[0-9]+E[±][0-9]+,即數字的整數部分隻有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負号即使對正數也必定明确給出。
現以科學計數法的格式給出實數 A,請編寫程式按普通數字表示法輸出 A,并保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即一個以科學計數法表示的實數 A。該數字的存儲長度不超過 9999 位元組,且其指數的絕對值不超過 9999。
輸出格式:
對每個測試用例,在一行中按普通數字表示法輸出 A,并保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
輸出樣例 1:
輸入樣例 2:
輸出樣例 2:
AC代碼
- 要求有效位被保留。而至于無效的0不去掉也能通過,如下:
輸入
輸出
- 以下代碼沒有去掉無效位,用了幾個字元串處理函數,也可以自己寫語句實作
#include<stdio.h>
#include<string.h>
int main(){
char number[20000],*p_int,*p_flo,*p_pow;
gets(number);
p_int=strtok(number,"."); //字元型整數部分
p_flo=strtok(NULL,"E"); //字元型小數部分
p_pow=strtok(NULL,"E"); //字元型指數部分
int interger,pow;
interger=atoi(p_int); //獲得int型整數部分
pow=atoi(p_pow); //獲得int型指數部分
if(pow>=0){ //指數大于0
printf("%d",interger); //輸出整數部分
int i;
for(i=0;*p_flo;i++,p_flo++){ //輸出小數部分
if(i==pow)printf("."); //相應位置加小數點
printf("%c",*p_flo);
}
while(i<pow){ //補零
printf("0");
i++;
}
}
else{ //指數小于零
if(interger<0){ //整數部分小于零
printf("-"); //輸出負号
interger=-interger;
}
pow=-pow;
for(int i=0;i<pow;i++){ //小數點前移,補零
printf("0");
if(i==0)printf(".");
}
printf("%d%s",interger,p_flo);
}
return 0;
}