[PAT乙级]1024. 科学计数法 (20)

来源:互联网 发布:能离线翻译软件 编辑:程序博客网 时间:2024/05/17 02:38

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

思路:

  • 分成两种情况
  • 指数为正数时,小数点右移,有效位最后需不需要加0
  • 指数为负数时,小数点左移,小数点后需要加几个零

代码:

#include <iostream>#include <string>using namespace std;int main(){    string s;    cin >> s;    if(s[0] == '-')        cout << '-';    bool t = true;//指数为正数    int pose = 0;    for(int i=0; i<s.size(); i++){        if(s[i] == 'E'){            pose = i;            if(s[i+1] == '-')                t = false;//指数为负数            break;        }    }    int after = 0;    for(int i=pose+2; i<s.size(); i++)        after = (s[i]-'0') + after*10;    if(t){//指数为正数        if (pose - 3 < after) {//指数为正数且最后需要加0            if (s[1] != '0')                cout << s[1];            for (int i = 3; i < pose; i++) {                if (s[i] >= '0' && s[i] <= '9') {                    cout << s[i];                }            }            for (int i = 0; i < after - (pose - 3); i++)                cout << "0";        }        else {//指数为正数且最后不需要加0            if (s[1] != '0')                cout << s[1];            for (int i = 3; i < pose; i++) {                if (i == 3 + after)                    cout << ".";                if (s[i] >= '0' && s[i] <= '9')                    cout << s[i];            }        }    }else{//指数为负数        if(after > 0){            cout << "0.";            for(int i=1; i<after; i++)                cout << "0";            for(int i=1; i<pose; i++){                if(s[i]>='0' && s[i]<='9')                    cout << s[i];            }        }else{//指数为0            for(int i=1; i<pose; i++){                if(i == 2)                    cout << ".";                if(s[i] >= '0' && s[i] <= '9')                    cout << s[i];            }        }    }    return 0;}