之前写乙级的时候写了个自己都看不懂的写法【PAT乙级 字符串】1024 科学计数法 (20 分)
现在再在甲级写一遍逻辑清楚了很多
#include<bits/stdc++.h>
using namespace std;
string S;
string num;
int main() {
cin >> S;
if(S[0] == '-') cout << "-";
num.insert(num.begin(), S[1]);
// 寻找字母E的位置,并把数字部分存储在num中
int i;
for(i = 3;S[i] != 'E';++i)
num += S[i];
int Epos = i;
// 得出指数部分的数字
int exp = 0, start_of_exp;
for(start_of_exp = Epos + 2;S[i] != '0';++i){
} // 跳过指数部分的0
for(i = start_of_exp;i < S.size();++i)
exp = exp * 10 + (S[i] - '0');
if(S[Epos + 1] == '+'){
// 指数的正负号为正
if(exp < num.size()-1) {
// +1.23400E+03 +1.23400E+04
for(i = 0;i < num.size();++i) {
cout << num[i];
if(i == exp)
cout << '.';
}
}
else{
// +1.23400E+05 +1.23400E+06
cout << num;
for(i = 0; i < exp - (num.size()-1) ;++i)
cout << '0';
}
} else {
// +1.23400E-03 +1.23400E-08
cout << "0.";
for(i = 0;i < exp-1;++i)
cout << '0';
cout << num;
}
return 0;
}