PAT乙级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 

AltHappy everyday!


   转载规则


《PAT乙级1024 科学计数法》 ZS 采用 知识共享署名 4.0 国际许可协议 进行许可。
 上一篇
My First Blog My First Blog
我的第一篇GitHub博客感谢BY 前人栽树, 后人乘凉
2019-03-19
下一篇 
模拟除法 模拟除法
PTA 乙级1017A除以B(模拟除法) ,有点意思,题目不是很难就是很难。长点心,想的全面点。 题目 本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=
2019-02-22
  目录