C++学习之路 | PTA乙级—— 1024 科学计数法 (20 分)(精简)
1024 科學(xué)計(jì)數(shù)法 (20 分)
科學(xué)計(jì)數(shù)法是科學(xué)家用來表示很大或很小的數(shù)字的一種方便的方法,其滿足正則表達(dá)式 [±][1-9].[0-9]+E[±][0-9]+,即數(shù)字的整數(shù)部分只有 1 位,小數(shù)部分至少有 1 位,該數(shù)字及其指數(shù)部分的正負(fù)號即使對正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù) A,請編寫程序按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留。
輸入格式:
每個(gè)輸入包含 1 個(gè)測試用例,即一個(gè)以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù) A。該數(shù)字的存儲(chǔ)長度不超過 9999 字節(jié),且其指數(shù)的絕對值不超過 9999。
輸出格式:
對每個(gè)測試用例,在一行中按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400E-03
輸出樣例 1:
0.00123400
輸入樣例 2:
-1.2E+10
輸出樣例 2:
-12000000000
#define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<string> #include<algorithm> using namespace std; int main() {string str, str_new;cin >> str;int x = str.find('E');//查找E所在位置int sum = atoi((str.substr(x + 1)).c_str());//將E之后字符轉(zhuǎn)換為數(shù)字for (int i = 0; i < x; i++)//將E之前的字符存到新的數(shù)組{if (str[i] == '.' || str[i] == '+' || str[i] == '-')continue;str_new.push_back(str[i]);}if (sum > 0)//如果大于0{if (sum < str_new.size() - 1)//如果小于前面數(shù)字的長度,只需要插入點(diǎn)str_new.insert(sum + 1, 1, '.');else if (sum > (str_new.size() - 1))//如果大于,需要補(bǔ)零{int y = sum - (str_new.size() - 1);for (int i = 0; i < y; i++){str_new.push_back('0');}}}else//小于零情況{for (int i = 0; i < abs(sum); i++)//在前面補(bǔ)零{str_new.insert(0, 1, '0');}str_new.insert(1, 1, '.');//插入點(diǎn)}if (str[0] == '-')//負(fù)數(shù)需要插入-號{str_new.insert(0, 1, '-');}cout << str_new; }總結(jié)
以上是生活随笔為你收集整理的C++学习之路 | PTA乙级—— 1024 科学计数法 (20 分)(精简)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux 无法打开.ttf_win7系
- 下一篇: C++学习之路 | PTA乙级—— 1