1024 科學計數法 (20分)
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 [±][1-9].[0-9]+e[±][0-9]+,即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。
現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即乙個以科學計數法表示的實數 a。該數字的儲存長度不超過 9999 位元組,且其指數的絕對值不超過 9999。
輸出格式:
對每個測試用例,在一行中按普通數字表示法輸出 a,並保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400e-03
輸出樣例 1:
0.00123400
輸入樣例 2:
-1.2e+10
輸出樣例 2:
-12000000000
【分析】
首先找到e的下標pos,e的左邊為【數字部分】,e的右邊為【指數部分】用來控制小數點——左邊為s.substr(1,i-1)
而右邊為s.substr(i+1)
。接著按指數為正負兩種情況討論。(指數為0需要特判。)
1.指數為正,則小數點右移。
【小數點應新增的下標位置】:exp+2(擷取之後的字串)
【原小數點與e之間的數字個數】:pos-3
【多餘的0的個數】exp-(pos-3)
2.指數為負,則小數點左移。需要補abs()-1個0。
【stl庫函式說明】
include
s.substr(起始下標, 擷取長度);//擷取子串
s.substr(i:int)//從下標i開始到尾部的子串
int n = stoi(s)//字串轉int
#include
#include
#include
using
namespace std;
intmain()
} string num = s.
substr(1
, pos -1)
; string exp = s.
substr
(pos +1)
;int n =
stoi
(exp);if
(s[0]==
'-')cout <<
'-';
if(n ==
0)cout << num;
if(n <0)
}else
for(
int i =
0; i < n -
(pos -3)
; i++)}
else
if(n == pos -3)
}else
if(n < pos -3)
cout << num[i];}
}}return0;
}
PAT 1024 科學計數法 20 分
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...
PAT乙級 1024 科學計數法 20分
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...
PAT 1024 科學計數法 20分
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數 a,請編寫程式按普通數字表示法輸出 a,並保證所有有效位都...