科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式本題主要是根據輸入來控制相應的輸出,一些細節較多,容易犯低階錯誤。設定字元陣列以接收輸入的科學計數法格式的數字,輸入的同時需要計算出指數的數值大小以備後面直接使用;之後,首先檢查數字的符號,[+-] [1-9].[0-9]+e[+-][0-9]+
,即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都被保留。
每個輸入包含 1 個測試用例,即乙個以科學計數法表示的實數 a。該數字的儲存長度不超過 9999 位元組,且其指數的絕對值不超過 9999。
對每個測試用例,在一行中按普通數字表示法輸出 a,並保證所有有效位都被保留,包括末尾的 0。
+1.23400e-03
0.00123400
-1.2e+10
-12000000000
+
不輸出,-
需要輸出;接著,按指數的符號分以下兩種情況處理:
指數符號為-
若指數數值為0,則直接輸出數字的有效數值部分即可(即e
之前的數值部分);否則,小數點需要向左進行相應的移動(小數點在第一位0之後),並補上相應個數的0(在小數點與原有效數值的第一位之間)。
指數符號為+
若指數數值為0,則直接輸出數字的有效數值部分即可(即e
之前的數值部分);否則,小數點需要向右進行相應的移動,若小數點未移動出有效數值部分,則在相應位置需要輸出小數點,若小數點移動出了有效數值部分,則不需要輸出小數點,並在右側補上相應個數的0。
小提示:請將以下**儲存為.cpp
格式(c++程式)左右滑動**以檢視完整**
#include
#define max 9999
using
namespace std;
intmain()
if(flag)}if
(sci_a[0]
=='-'
)//數字的符號為-時需要輸出,為+時不需輸出
int i =1;
if(loc ==
'-')
}while
(sci_a[i]
!='e'
) i++;}
}else
else
printf
("%c"
,sci_a[i]);
} i++
;//注意不要忽略
PAT 乙級1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...
PAT 乙級 1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...
PAT 乙級1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...