轉跳點:?
1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 [+-][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
這道題可有意思了,我都被逼的去學了一點正規表示式(原本不想用正則的,但寫到一半發現太麻煩,就不寫了(捂臉),果然我還是個菜菜)。這道題除了輸入之外,沒有太多難的地方,就是注意正負號,和小數字的保留。
我**壓縮了一下,時間方面不太理想。(為什麼要精簡**?可能我腦子有坑吧)
1 #include 2 #include 3 #include 4 #define maxsize 10000
5 6 int main(void)
7 17 exponent--; //0 -> exponent, 所以-1
18 printf("%d", abs(integer)); //輸出第一位
19 for (int i = 0; i < strlen(decimal) || i < exponent; i++)
20
24 25 return 0;
26 }
我原本寫了乙個60來行的**,發現太長,就放棄了,沒用正則,果然**短看起來就是舒服。(使勁浪費時間,看不見)
下面這個就是正則的部分
%d.%[0-9]e%d
其實吧,用到正則的就只有這裡%[0-9]e這裡表示從.到 e 之間是數字 0~9 的字元都會儲存下來,還有,正規表示式本來就是用來處理字串的,不要問我為什麼,自行度娘,詳細的正規表示式的用法我會在額外更一篇部落格的,(等我學完再說)
pta不易,諸君共勉!
1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...
1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...
1024 科學計數法
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...