1024 科學計數法 20

2021-08-22 19:17:21 字數 1247 閱讀 1689

1024 科學計數法 (20)(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

這個真的是,一直部分正確,找bug找了兩小時,還是自己邏輯能力不夠,比如沒有考慮指數為0的情況,沒有考慮小數點是不是一定不輸出,也沒有考慮過當輸入+0.000001e+10等前面的零不需要輸出的情況,總而言之,改的我心好累,不過也算是一種收穫!

#include 

#include

using namespace std;

int main()

if(str[0] == '-')

cout<<"-";

if(str[cnt+1] == '-') //用來判斷指數部分是正數還是負數

flag = 1;

else

flag = 0;

for(i = cnt + 2; i < len; i++)

if(flag == 0) //指數部分是正數

else

if(i == 1 && str[i] != '0')

else

if(i > 2)

if(flag1 == 1)

}else}}

while(sum > 0) //指數還沒為零,而小數已經沒了的時候,用零補充

}else

else

if(sum >= 1)

}for(i = 1; i < cnt ; i++)

else

cout<}

}return

0;}

1024 科學計數法 20

時間限制 100 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 hou,qiming 科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數...

1024 科學計數法 20

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...

1024 科學計數法 20

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...