C++学习之路 | PTA乙级—— 1020 月饼 (25分)(带注释)(精简)
1024 科學(xué)計(jì)數(shù)法 (20分)
科學(xué)計(jì)數(shù)法是科學(xué)家用來(lái)表示很大或很小的數(shù)字的一種方便的方法,其滿(mǎn)足正則表達(dá)式 [±][1-9].[0-9]+E[±][0-9]+,即數(shù)字的整數(shù)部分只有 1 位,小數(shù)部分至少有 1 位,該數(shù)字及其指數(shù)部分的正負(fù)號(hào)即使對(duì)正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù) A,請(qǐng)編寫(xiě)程序按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留。
輸入格式:
每個(gè)輸入包含 1 個(gè)測(cè)試用例,即一個(gè)以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù) A。該數(shù)字的存儲(chǔ)長(zhǎng)度不超過(guò) 9999 字節(jié),且其指數(shù)的絕對(duì)值不超過(guò) 9999。
輸出格式:
對(duì)每個(gè)測(cè)試用例,在一行中按普通數(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ù)字的長(zhǎng)度,只需要插入點(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ù)需要插入-號(hào){str_new.insert(0, 1, '-');}cout << str_new; }總結(jié)
以上是生活随笔為你收集整理的C++学习之路 | PTA乙级—— 1020 月饼 (25分)(带注释)(精简)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 重庆高职高专计算机排名,重庆十大大专排名
- 下一篇: C++学习之路 | PTA乙级—— 10