【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;
int main(){
string s, str, str2;
cin >> s;
s.erase(s.begin()+2);
if(s[0] == '-') str2 += '-';
s.erase(s.begin());
int index = s.find('E');
str = s.substr(0, index);
bool flag = false;
if(s[index+1] == '+') flag = true;
else flag = false;
s = s.substr(index+2, s.size());
int num = stoi(s);
if(flag == false){
str.insert(0, num, '0');
str.insert(1, ".");
str2 += str;
cout << str2;
}else{
if(num+1 == str.size()){
str2 += str;
}else if(num+1 > str.size()){
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字符。
|