0
点赞
收藏
分享

微信扫一扫

【Java 实现经典算法】科学计数法

千行 2022-02-28 阅读 70

题目描述

  • 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法
  • 其满足正则表达式[±][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;
  • 正指数往后移动小数点,需要时补0或去掉小数点;
  • 表示数值时正号不显示,负号显示;

代码

package com.liuyong666.pat;

import java.util.Scanner;

public class Main {
    
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String a = sc.nextLine();
        /**
        * isFuZhiShu	指数是否为负
        * zhishu		指数的值
        * e_index		E的索引值
        * dian_index	.的索引值
        * quE			E之前数值的绝对值
        */
        boolean isFuZhiShu = false;
        int zhishu = Integer.parseInt(a.substring(a.lastIndexOf('E') + 1));
        int e_index = a.indexOf('E');
        int dian_index = a.indexOf('.');
        StringBuffer quE = new StringBuffer(a.substring(1,e_index));
        
        //判断输入字符串是否是负指数
        if(a.charAt(a.lastIndexOf('E') + 1) == '-'){
            isFuZhiShu = true;
        }
        
        //负指数的情况下,在前边加若干个0,再加个.再加个0
        if(isFuZhiShu){
            if(-zhishu > 0){
                quE.deleteCharAt(1);
                for(int i = 0; i < -zhishu - 1; i++){
                    quE.insert(0, '0');
                }
                quE.insert(0, '.');
                quE.insert(0, '0');
            }
            //输出需要把正负表示出来,正号不显示,负号显示
            System.out.println((a.charAt(0) == '+' ? "":"-") + quE.toString());
            
            //正指数的情况下,往后移动.的位置,按照需求补充0
        }else{
            if(zhishu > 0){
                quE.deleteCharAt(1);
                int dian_e_len = e_index - dian_index - 1;
                if(dian_e_len - zhishu > 0){
                    quE.insert(zhishu + 1, '.');
                    
                }else{
                    for(int i = 0; i < zhishu - dian_e_len; i++){
                        quE.insert(quE.length(), '0');
                    }
                }
                
            }
            System.out.println((a.charAt(0) == '+' ? "":"-") + quE.toString());
        }
    }
}
举报

相关推荐

0 条评论