测试点错的来:1024 科学计数法 (20分)
生活随笔
收集整理的這篇文章主要介紹了
测试点错的来:1024 科学计数法 (20分)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
立志用更少的代碼做更高效的表達
PAT乙級最優題解——>傳送門
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表達式 [±][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
思路分析
大體思路:
幾點注意事項
1、輸入時, 使用了[^E]標識符, 它的意思和%s一致,不過不是遇到空格或回車結束,而是遇到E字符結束。
2、對于模擬題,一定要先想好思路, 縷清脈絡再敲, 否則會越敲越亂。一般來說,我喜歡話樹形圖來表示分支和操作。
3、對于模擬題,盡量使用string或char*來進行存儲, 使用整型變量存儲很可能漏掉前導零。 如: +3.00001E-3這組數據。
代碼展示
#include<bits/stdc++.h> using namespace std; int main() {char cc[10000]; long long x2; char c1, c2, c3;scanf("%c%c.%[^E]E%c%lld", &c1, &c3, cc, &c2, &x2);string s; if(c2 == '-') {for(int i = 0; i < x2; i++) { if(i==1) s += '.';s += '0';}s += c3;s += cc;} else {s+= c3;s+= cc;if(s.length() < x2) {int len = s.length(); for(int i = 0; i < x2-len+1; i++) s+='0'; } else if(s.length() > x2+1){s.insert(x2+1, ".");}}if(c1=='-') s.insert(0,"-");cout << s; return 0; }總結
以上是生活随笔為你收集整理的测试点错的来:1024 科学计数法 (20分)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Fibonacci Tree HDU -
- 下一篇: 【传智播客】Javaweb程序设计任务教