科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 [+-][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
比較簡單的是用sccanf的正則匹配啊喂!(
不然就想好邏輯自行模擬:
符號+-直接輸出,無影響;e前面的數字和後面的數字分別儲存,接下來分情況;
後面數字<0,輸出0. 再輸出abs(n)-1個0 再輸出前面的所有數字。<——①
後面數字》0,分情況。即補0,不補,動.三種,當然可以當成兩種處理。
先輸出第⼀個字元,然後將
t中盡可能輸出
n個字元,如果
t已經輸出到最後⼀個字元
(j == t.length())
那
麼就在後⾯補
n-cnt個0
,否則就補充⼀個⼩數點
. 然後繼續輸出
t剩餘的沒有輸出的字元
把邏輯理清後,重點儲存個數就好了~
#include#includeint main()
int zf=0;
if(a[++i]=='-') zf=1; //+0 -1
int shu=0;
i++;
for(;iif(zf==1)elseelse}}
return 0;
}
1024 科學計數法 (20 分)
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...
1024 科學計數法 (20 分)
1024 科學計數法 20 分 科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表...
1024 科學計數法 (20 分)
1.指數小於0 例 1.23e 3,轉為普通數字 0.00123,指數為3,則小數點後帶2個0,規律如下 設指數為e,小數點後就有e 1個0。2.指數大於等於0 這個又可以分成兩個情況 這個在乙個迴圈內就能解決 小數點後移e位,e位前如果沒有數值就補0,e位後如果沒有數值了就不加小數點了 的意思是 ...