1024. 科学计数法 (20)

原创 2016年06月01日 14:14:20

1024. 科学计数法 (20)

时间限制 100 ms
内存限制 65536 kB
代码长度限制 8000 B
判题程序 Standard
作者 HOU, Qiming

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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

原题地址: https://www.patest.cn/contests/pat-b-practise/1024

这道题刚开始没有看清楚,因为整数部分可以是0,,自己弄麻烦了,导致最后两个test没有过,今天看了别人的代码才明白,但也是测试了好久才过。
计算出小数部分的位数分清楚情况可以了


#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;

char str[10000];

void solve()
{
    char num[10000] = {0};  //去掉小数点后的数字串 
    int len = strchr(str, 'E') - str - 3;   //小数部分长度 

    num[0] = str[1];
    strncpy(num + 1, str + 3, len);

    int ex = atoi(str + len + 4);   //获取指数 
    int pos = 1;    //小数点位置 

    if(str[0] == '-')
        cout << '-';

    if(ex > 0){
        pos += ex;
        if(len < ex){
            cout << num;
            for(int i = len; i < ex; i ++)
                cout << '0';
        }
        else if(len > ex){
            for(int i = 0; i < pos; i ++)
                cout << num[i];
            cout << '.';
            for(int i = pos; i < len + 1; i ++)
                cout << num[i];
        }
        else{
            cout << num;
        }
    }

    else if(ex < 0)
    {
        cout << "0.";
        for(int i = ex + 1; i < 0; i ++){
            cout << '0';
        }
        for(int i = 0; i < len + 1; i ++)
            cout << num[i];
    }

    else{
        for(int i = 0; i < pos; i ++)
            cout << num[i];
        cout << '.';
        for(int i = pos; i < len + 1; i ++)
            cout << num[i];
    }

    cout << endl;
}

int main()
{
    cin >> str;
    solve();
    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

PAT乙级—1024. 科学计数法 (20)-native

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]”.”[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位,该数字及其指数部分...
  • wanmeiwushang
  • wanmeiwushang
  • 2016年05月08日 22:32
  • 1346

1024. 科学计数法 (20)

1024. 科学计数法 (20) 时间限制 100 ms 内存限制 32000 kB 代码长度限制 8000 B ...
  • JANESTAR
  • JANESTAR
  • 2014年06月07日 13:25
  • 2132

浙大 PAT 1024. 科学计数法 (20)

1024. 科学计数法 (20) 时间限制 100 ms 内存限制 32000 kB 代码长度限制 8000 B ...
  • IAccepted
  • IAccepted
  • 2014年03月02日 23:22
  • 3507

1024. 科学计数法 (20)

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位,该数字及其指数部分...
  • u013802188
  • u013802188
  • 2014年07月09日 16:46
  • 431

1024. 科学计数法 (20)

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]”.”[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位,该数字及其指数部分...
  • Wanglinlin_bfcx
  • Wanglinlin_bfcx
  • 2017年07月14日 13:34
  • 73

1024.科学计数法 (20)

1024.科学计数法 (20)时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 科学计数法是...
  • youth_shouting
  • youth_shouting
  • 2017年07月24日 20:14
  • 82

【PAT】(乙级)1024. 科学计数法 (20)

1024. 科学计数法 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 一、题目科学计数法是科学家用...
  • R3lish
  • R3lish
  • 2016年08月11日 19:19
  • 434

1024. 科学计数法 (20)

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位,该数字及其指数部分...
  • qq_38181539
  • qq_38181539
  • 2017年08月01日 17:55
  • 58

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

1024. 科学计数法 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B ...
  • hungryfoolisher
  • hungryfoolisher
  • 2017年05月05日 21:23
  • 193

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

1024. 科学计数法 (20)原题链接 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]”.”[0-9]+E[+-][0-9]+,即数字的整数部分只有...
  • whl_program
  • whl_program
  • 2017年08月03日 21:55
  • 125
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:1024. 科学计数法 (20)
举报原因:
原因补充:

(最多只允许输入30个字)