1073 Scientific Notation (20 分)
-
题目大意:将用科学计算法表示的数字转变成传统数字,并且保存传统数字的格式(后面有几个0就要保存几个0)
-
思路:用字符串方法输出!不用考虑数学问题!!!!
-
知识点:
- substr()
- stoi(expo), stod(expo)
- to_string(a): a若为double型变量只会保存6位小数,所以这里不能用这个方法
-
代码:
#include <iostream> #include <string> using namespace std; int main(){ string num, ex_num, expo; cin >> num; int i; for(i = 0; i < num.length(); i++) // 找到E的下标 if(num[i] == 'E') break; ex_num = num.substr(1, i - 1); // E前的数字部分(不包括负号) expo = num.substr(i + 1); // E后的指数部分 if(num[0] == '-') // 输出负号 cout << num[0]; if(stoi(expo) < 0){ // 指数为负数 cout << "0."; for(i = 0; i < - stoi(expo) - 1; i++) cout << "0"; for(i = 0; i < ex_num.length(); i++){ // 按原格式输出 if(ex_num[i] == '.') continue; cout << ex_num[i]; } }else{ // 指数为正数 if(stoi(expo) >= ex_num.length() - 2){ // 结果为整数 for(i = 0; i < ex_num.length(); i++){ if(ex_num[i] == '.') continue; cout << ex_num[i]; } for(i = 0; i < stoi(expo) - ex_num.length() + 2 ; i++) cout << "0"; }else{ // 结果为小数 for(i = 0; i < ex_num.length(); i++){ if(ex_num[i] == '.') continue; cout << ex_num[i]; if(i == stoi(expo) + 1) cout << "."; } } } return 0; }
-
总结:
- 遇到卡住的问题不要死磕!不要死磕!不要死磕!
- 我之前一直想把科学计数法的数字拆成两个数字(数字和指数),数字用
to_string(a)
变成字符串,然后通过找规律、遍历字符串而输出想要的效果,但是a为浮点数时,to_string(a)
只会保留小数点后6位小数,若测试数据的数字部分为长度超过7就处理不了。我参考了柳诺的方法,发现单纯把数字方程字符串输出这样简单很多。