【PAT甲级 字符串】1073 Scientific Notation (20 分)

之前写乙级的时候写了个自己都看不懂的写法【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;
}

猜你喜欢

转载自blog.csdn.net/MYMarcoreus/article/details/114413712
今日推荐