PAT乙级1024 科学计数法

铛铛铛, 感觉这道题有点难,不过在抡蒙纂,瞎写之下居然过了,回顾一下加深印象?

1024

    • 题目
    • 题解
      • 看题分析一下
      • 话不多说放代码

题目

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

题解

看题分析一下

  • 指数可以高达999,所以直接放弃使用数字表示,转而选用字符串或者直接输出结果(因为在输出的过程中不在涉及到输入), ok 我选择直接输出,方便点。
  • 还有就是要保留所有有效位数,意思就是所有E之前的数字都要输出。

话不多说放代码

牛皮的C++

#include
#include

using namespace std;

int main()
{
    string str;
    cin>>str;

    int e = str.find("E"); //找到E的位置
    int index = 0; //指数大小
    int zhi;//指数正负
    if(str[e + 1] == '+') zhi = 1;
    else zhi = -1;
    for(int i = e + 2;i < str.size();i ++) //求指数
    {
        index = index * 10 + str[i] - '0';
    }

    if(str[0] == '-') cout<<'-';//如果为负直接输出符号

    if(zhi < 0) //如果指数为负
    {
        cout<<"0."; //输出前导零
        for(int i = 0;i <index - 1;i ++) //输出多余的零
        {
            cout<<'0';
        }
        cout<<str[1];//输出原来的整数位
        for(int i = 3;i < e;i ++)//循环输出E之前的数据
        {
            cout<<str[i];
        }
    }
    else //指数大于零
    {
        cout<<str[1];//输出原来的整数位
        for(int i = 3;i < index + 3 || i < e;i ++) //输出E之前的数和多余的零
        {
            if(i < e) cout<<str[i]; //如果i
            else cout<<'0'; //如果指数比较大,则还要输出多余0
            if(i - 3 == index - 1 && (i < e - 1 || i < index + 3 - 1))//如果本来的位数比指数还大则要补上小数点,还有保证小数点没有补在末尾
            	cout<<'.';
        }
    }
    cout<<endl;
    return 0;
}

Happy everyday!

你可能感兴趣的:(PTA)