PAT乙級1024 科學計數法(C C )

2021-09-23 10:47:52 字數 1580 閱讀 1526

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式[+-] [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,並保證所有有效位都...