【PAT乙级】1024科学计数法(20)
虽然做出来了,但是应该有更简便的方法,先码一个有空再来修改~
题目要求:
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[±][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 结尾无空行
思路:
将非数字部分的小数点和符号都去掉最后根据情况添加。
三个字符串:s、str、str2——分别保存:输入、数字部分、输出
- 去掉小数点;
- 处理符号,正号省略,负号保存到str2中,去掉符号位;
- 找到E的下标,截取字符串将输入字符串s分为E前和E后两个部分,再对两个部分非数字部分进行处理,最后根据情况添加小数点进行输出。
#include<bits/stdc++.h>
using namespace std;
/*
B1024:科学计数法 +1.23400E-03
*/
int main(){
string s, str, str2;//输入字符串 数字部分 输出字符串
cin >> s;
//删除小数点
s.erase(s.begin()+2);
// cout << "s:" << s << endl;//+123400E-03
//删除首位符号
if(s[0] == '-') str2 += '-';
s.erase(s.begin());
// cout << "s:" << s << endl;//123400E-03
//找到E的位置 得到E前后两部分
int index = s.find('E');
// cout << index << endl;
str = s.substr(0, index);//E前部分数字:123400
// cout << "str:" << str << endl;//123400
bool flag = false;//E后符号位
if(s[index+1] == '+') flag = true;
else flag = false;
s = s.substr(index+2, s.size());//E后部分数字:03
// cout << "s:" << s << endl;
int num = stoi(s);
//3、根据情况转化
if(flag == false){
str.insert(0, num, '0');//负号,前面添加0
str.insert(1, ".");//添加小数点
str2 += str;
cout << str2;
}else{
if(num+1 == str.size()){
str2 += str;
}else if(num+1 > str.size()){
//正号,小数点后移num位
str.insert(str.size(), num+1-str.size(), '0');
str2 += str;
}else{
str.insert(num+1, ".");
str2 += str;
}
cout << str2;
}
return 0;
}
一些错误:
- 把erase写成了earse;
- 对erase的用法不够清晰。
比如str.erase(str.begin()+2);是删除某一位的字符
str.erase(5);是删除从下标5开始到结束的所有字符 - 对insert的用法不够清晰,插入小数点时要用双引号不能用单引号,str.insert(num+1, “.”);因为小数点不属于char字符。