专栏首页卡尼慕1024 科学计数法 (20 分)

1024 科学计数法 (20 分)

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

我的代码

难度不大,主要细心一点分类讨论好就行了。

// 1024 科学计数法 (20 分).cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <iostream>
#include <string>
using namespace std;
//输出有效数字
void print(string s, int point_index, bool point) {
    bool E_flag = false;
    for (int i = 0; i < s.size(); i++) {
        if (s[i] == 'E')
            E_flag = true;
        if (point && point_index == i)
            cout << ".";
        if (!E_flag && s[i] >= '0' && s[i] <= '9')
            cout << s[i];
    }
}

//判断幂的符号以及数值
int judge(string s) {
    bool E_flag = false;
    int res = 0;
    int tmp = 1;
    for (int i = s.length() - 1; i > 0; i--) {
        if (s[i] == 'E')
            E_flag = true;
        if (!E_flag && s[i] >= '0' && s[i] <= '9') {
            res += (s[i] - '0') * tmp;
            tmp *= 10;
        }
        else if (!E_flag && s[i] == '-') {
            res *= -1;
        }
    }
    return res;
}
int main(){
    string input;
    cin >> input;
    int flag;
    int num = judge(input);
    //得到E的位置
    int E_index;
    for (int i = 0; i < input.size(); i++) {
        if (input[i] == 'E')
            E_index = i;
    }
    int zero_count = 0;
    for (int i = 0; i < E_index; i++) {
        if (input[i] == '0')
            zero_count++;
    }
    //如果数值为0
    if (zero_count + 1 >= E_index) {
        cout << "0";
        return 0;
    }
    //如果指数为0
    else if (num == 0) {
        for (int i = 0; i < E_index; i++) {
            if(input[i] != '+')
                cout << input[i];
        }
    }
    else {
        if (input[0] == '-')
            cout << "-";
        if (num < 0) {
            cout << "0.";
            for (int i = 0; i < (-1 * num) - 1; i++)
                cout << "0";
            print(input, 0, false);
        }
        if (num > 0) {
            if (num >= E_index - 3) {
                print(input , 0,false);
                for (int i = 0; i < num - (E_index - 3); i++)
                    cout << "0";
            }
            else {
                print(input, num + 3, true);
            }

        }
    }
}

本文分享自微信公众号 - 卡尼慕(gh_40138f7dc7d3),作者:卡尼幕

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-09-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 1042 字符统计 (20 分)

    输入在一行中给出一个长度不超过 1000 的字符串。字符串由 ASCII 码表中任意可见字符及空格组成,至少包含 1 个英文字母,以回车结束(回车不算在内)。

    可爱见见
  • 1031 查验身份证 (15 分)

    可爱见见
  • 1023 组个最小数 (20 分)

    可爱见见
  • 1042 字符统计 (20 分)

    输入在一行中给出一个长度不超过 1000 的字符串。字符串由 ASCII 码表中任意可见字符及空格组成,至少包含 1 个英文字母,以回车结束(回车不算在内)。

    可爱见见
  • 2016广东工业大学新生杯决赛网络同步赛暨全国新生邀请赛 题解&源码

    Problem A: pigofzhou的巧克力棒 Description 众所周知,pigofzhou有许多妹子。有一天,pigofzhou得到了一根巧克力棒...

    Angel_Kitty
  • 【Gym 100971J】Robots at Warehouse

    链接 给你一个n*m的地图,'#'代表墙,‘.’代表可走的,1代表1号机器人,2代表2号机器人,机器人可以上下左右移动到非墙的位置,但不能走到另一个机器人身上。...

    饶文津
  • UNPv1第五章:TCP客户服务器程序实例

    这个简单的例子是完成下述功能的一个回射服务器: 1. 客户从标准输入读一行文本,写到服务器上 2. 服务器读入此行,并回射给客户 3. 客户读...

    提莫队长
  • 配置tomcat限制指定IP地址访问后端应用

    1. 场景 后端存在N个tomcat实例,前端通过nginx反向代理和负载均衡。 tomcat1 tomcatN | ...

    2Simple
  • MediaPlayer(九)--reset()流程

    frameworks/base/media/java/android/media/MediaPlayer.java

    小蚂蚁与大象
  • leetcode-788-Rotated Digits(使用vector替代if else的逐个判断)

    chenjx85

扫码关注云+社区

领取腾讯云代金券