【Java】PAT Basic Level 1024 科学计数法

题目 1024 科学计数法

作者 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

思路

这道题的主要思路:首先把读取的字符串拆分成子串,以便取出底数和指数部分,然后根据指数的正负来判断可能需要在数字的右边还是左边补零,最后输出结果即可。

这其中有几个问题的处理方式,我记录在此。

1.对输入字符串的拆分

以往PAT的题目,输入内容都是以空格为间隔的,那么只要用String.split()配合简单的正则表达式,即可将输入内容以空格为分隔符切分为多个子串,返回字符串数组。如下。

//获取输入流对象
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));//将输入的一行内容 以一个或多个空格为分隔符 切分为字符串数组
String[] arr = br.readLine().split(" +");     
/*readLine()读取一行输入,返回String,split()函数的参数是切分字符串的分隔符,返回String[]" +" 是正则表达式,表示一个或多个空格
*/

在这道题目中,也可以用“E”以及小数点“\\.”作为间隔符来切分子串。但这样得到的子串中仍然会包含正负号,还要再进一步处理。(小数点,写\\是为了转义,因为“.”在正则表达式中有特殊含义,表示匹配除了换行符外的任意字符。)

这道题目的输入,符合一个指定的正则表达式,那么其实就可以利用正则表达式来方便地切分字符串。切分的时候注意,Java并不知道我们希望怎样切分,所以写正则表达式的时候要用括号来表示分组,那么Java就会按照这个分组来切分子串。

根据正则表达式来切分字符串的具体方法,见代码。

        //待切分的字符串String str = "+1.230E-4";//输入的字符串所符合的正则表达式String pattern = "([+-])([1-9])(\\.)([0-9]+)(E)([+-])([0-9]+)";     /*注意要用括号来表示分组,每个分组会被切分为一个子串*///Pattern类用于编译正则表达式Pattern r = Pattern.compile(pattern);       //Matcher类用于根据正则表达式将字符串进行匹配Matcher m = r.matcher(str);    //优先处理特殊情况         if(!(m.find())) {                //若字符串与正则表达式匹配失败System.out.println("字符串输入有误,请根据正则表达式输入!");  //输出错误提示信息return;                     //程序返回}//若字符串与正则表达式匹配成功int count = m.groupCount();            //获取匹配到的子串数量String[] s = new String[count];         //新建字符串数组for (int i = 0; i < count; i++)       //遍历字符串数组s[i] = m.group(i+1);              //用group()方法获取每个子串,存到字符串数组中/*注意,group()方法的参数是从1开始的*///打印数组等后续代码

2.拼接字符串

这道题涉及对字符串的拼接处理,这其实比较耗时,如果频繁使用新建字符串,以及频繁使用substring()方法取子串的话,在PTA平台上容易超时。这里可以采用更高效的字符串拼接方法:StringBuilder类。需要拼接的时候,只要append()一下就可以,打印也很方便。使用方法如下。

StringBuilder strb = new StringBuilder();  
/* 
构造字符串,StringBuilder是一个可变对象,
可以降低字符串拼接的时间复杂度,不然在PTA平台上可能超时
*/strb.append("I Love ");    //追加一些内容strb.append("Java");        //在结尾再追加一些内容System.out.println(strb);    //直接放在println()函数中打印即可//打印结果:    I Love Java

3.switch语句

这道题中,正常情况下,指数前面的符号只会有正负两个值,正好就可以用switch语句,只需要两个case分支,顺道还可以有default来应对异常状况。当然也可以用if语句,只不过switch语句更快那么一点点,于是就用switch语句吧。


Java代码

最终所有测试点都测试通过。代码如下。

/*
功能:给定以科学计数法表示的一个数字,输出其普通表示形式*/
import java.io.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Main  {public static void main(String[] args) throws IOException{//接收输入BufferedReader br = new BufferedReader(new InputStreamReader(System.in));String str = br.readLine();     //读取科学计数法表示的数字//根据正则表达式进行匹配,将输入信息切分为子串String pattern = "([+-])([1-9])(\\.)([0-9]+)(E)([+-])([0-9]+)";      //输入字符串符合的正则表达式,注意要用括号来表示分组,每个分组会被切分为一个子串Pattern r = Pattern.compile(pattern);           //Pattern类用于编译正则表达式Matcher m = r.matcher(str);                     //Matcher类用于根据正则表达式将字符串进行匹配if(!(m.find())) {                //若字符串与正则表达式匹配失败System.out.println("字符串输入有误,请根据正则表达式输入!");   //输出错误提示信息return;                     //程序返回}//若字符串与正则表达式匹配成功int count = m.groupCount();            //获取匹配到的子串数量String[] s = new String[count];         //新建字符串数组for (int i = 0; i < count; i++)       //遍历字符串数组s[i] = m.group(i+1);                //用group()方法获取每个子串,存到字符串数组中//分析并生成数字的普通形式StringBuilder result = new StringBuilder();  // 构造字符串,StringBuilder是一个可变对象,可以降低字符串拼接的时间复杂度if("-".equals(s[0]))                         //生成开头的正负号result.append("-");int zhi = Integer.parseInt(s[6]);            //指数的数值if(zhi==0){                             //若指数为0,则直接输出整数和小数部分即可result.append( s[1] + s[2] + s[3]);System.out.println(result);return; }//若指数不为0switch(s[5]){       //判断指数的正负号case "+":           //如果指数为正数int di = s[3].length();      //底数部分的小数位数if(zhi >= di){                  //若指数比底数的小数位数多,则最终结果不会有小数点result.append( s[1] + s[3] );     //生成整数位、有效位for(int i=0;i<zhi-di;i++)result.append( "0");              //再把剩余的尾数0都加上}else{                           //若指数不如底数的小数位数多,则最终结果仍要有小数点result.append( s[1] + s[3].substring(0,zhi));   //生成整数位、整数部分的有效位result.append( s[2] + s[3].substring(zhi));      //生成小数点、小数部分的有效位} break;case "-":           //如果指数为负数result.append("0.");                 //生成整数位、小数点for(int i=0;i<zhi-1;i++)        //生成小数点后最高位的0result.append( "0");result.append( s[1] + s[3]);          //生成有效位break;default:System.out.println("输入有误!");break;}//打印输出System.out.println(result);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/121955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vuex 和 Redux 的区别?

Vuex和Redux是两个流行的JavaScript状态管理库&#xff0c;它们有一些相似之处&#xff0c;但也有一些区别。 区别&#xff1a; 语言&#xff1a;Vuex是为Vue.js框架设计的&#xff0c;而Redux是一个独立的库&#xff0c;可用于多种JavaScript框架或库。生态系统&#xff1a;…

提升技能,挑战自我——一站式在线题库小程序

在这个信息爆炸的时代&#xff0c;我们总是在寻找一种方式&#xff0c;让自己在众多的知识海洋中快速提升技能&#xff0c;挑战自我。今天&#xff0c;我要向大家推荐一款全新的在线题库小程序KD蝌蚪阿坤&#xff0c;它将帮助你实现这个目标。 KD蝌蚪阿坤是一款全面的在线题库…

5 个编写高效 Makefile 文件的最佳实践

在软件开发过程中&#xff0c;Makefile是一个非常重要的工具&#xff0c;它可以帮助我们自动化构建、编译、测试和部署。然而&#xff0c;编写高效的Makefile文件并不是一件容易的事情。在本文中&#xff0c;我们将讨论如何编写高效的Makefile文件&#xff0c;以提高我们的开发…

Python---练习:有一物,不知其数,三三数之余二,五五数之余三,七七数之余二,问物几何?

案例&#xff1a; 有一物&#xff0c;不知其数&#xff0c;三三数之余二&#xff0c;五五数之余三&#xff0c;七七数之余二&#xff0c;问物几何&#xff1f; 人话&#xff1a; 有一个数字&#xff0c;不知道具体是多少&#xff0c;用3去除剩2&#xff0c;用5去除剩3&#…

Linux中shell脚本中的变量

目录 一、变量的定义 二、shell脚本中变量的定义方法 1、变量名称 2、环境级别 3、用户级别 4、系统级别 5、删除设定的变量 三、变量的转译 1、转译 2、声明 3、变量的数组 四、Linux中命令的别名设定 五、用户环境变量的更改 脚本中的传参 1、非交互模式 2…

android studio启动Task配置

Android studio 高版本默认不开启Task配置&#xff0c;需要自己手动开启 1.低版本配置路径&#xff1a;&#xff08;复制他人图片&#xff09; 2.高版本路径&#xff1a;添加下图勾选配置即可 3.gradle task 3.1 初识task gradle中所有的构建工作都是由task完成的,它帮我们处…

Anaconda下载和安装

1.概述 1&#xff09;包含conda&#xff1a;conda是一个环境管理器&#xff0c;其功能依靠conda包来实现&#xff0c;该环境管理器与pip类似。 2&#xff09;安装大量工具包&#xff1a;Anaconda会自动安装一个基本的python&#xff0c;该python的版本Anaconda的版本有关。该…

2023年清洁电器行业数据分析:洗地机市场规模持续倍增,进入赛点

洗地机作为清洁电器领域的明星品类&#xff0c;正在成为继扫地机器人之后拉动清洁电器市场大盘的又一核心动力。 在清洁电器领域&#xff0c;扫地机器人、洗地机和吸尘器是三大热门品类。截至今年9月份&#xff0c;根据鲸参谋平台的数据显示&#xff0c;吸尘器的规模继续大幅下…

数据库、数据仓库相关

1. 数据库与数据仓库的区别 数据库 Database (Oracle, Mysql, PostgreSQL)主要用于事务处理。数据仓库 Datawarehouse (Amazon Redshift, Hive)主要用于数据分析。 数据库和数据仓库是两种不同的数据存储方式&#xff0c;它们的设计目的和使用场景也有所不同。数据库通常用于…

嵌入式 Tomcat 调校

SpringBoot 嵌入了 Web 容器如 Tomcat/Jetty/Undertow&#xff0c;——这是怎么做到的&#xff1f;我们以 Tomcat 为例子&#xff0c;尝试调用嵌入式 Tomcat。 调用嵌入式 Tomcat&#xff0c;如果按照默认去启动&#xff0c;一个 main 函数就可以了。 简单的例子 下面是启动…

系列十八、请描述下bean的生命周期

一、概述 bean的生命周期是指bean从创建到销毁的整个过程。 二、生命周期 bean的生命周期是指bean从创建到销毁的整个过程&#xff0c;大致可以分为如下四个过程&#xff1a; 2.1、实例化 实例化可以通过如下几种方式完成&#xff1a;&#xff08;参考系列十五&#xff09…

JPA联合主键

​ 在实际工作中&#xff0c;我们会经常遇到联合主键的情况&#xff0c;所以我用简单例子列举JPA两种实现联合主键的方式。 1、如何通过IdClass 实现联合主键 第一步:新建一个UserInfoID类&#xff0c;里面是联合主键 Data Builder NoArgsConstructor AllArgsConstructor pu…

【Luogu】 P5642 人造情感(emotion)

题目链接 点击打开链接 题目解法 考虑如何计算 f ( U ) f(U) f(U)&#xff0c;我不知道如何能想到下面的解法 一个技巧是把路径挂在 l c a lca lca 上 我们令 f u f_{u} fu​ 表示完全包含在 u u u 的子树中的路径的最大独立集 考虑转移&#xff0c;记 s u m u ∑ v…

maven之父子工程版本控制案例实战,及拓展groupId和artifactId的含义

<parent>标签 用于父子工程项目&#xff0c;什么是父子工程&#xff1f; 顾名思义&#xff0c;maven父子项目是一个有一个父项目&#xff0c;父项目下面又有很多子项目的maven工程&#xff0c;当然&#xff0c;子项目下面还可以添加子项目&#xff0c;从而形成一个树形…

Java架构师信息系统构建

目录 1 导学2 信息系统概述2.1 企业主要使用的信息化系统介绍3 业务处理系统3.1 业务处理系统TPS3.2 管理信息系统MIS3.3 决策支持系统DSS4 专家系统ES5 办公自动化系统OAS6 企业资源规划ERP7 典型信息系统架构模型8 信息化战略体系9 客户关系管理CRM10 供应链管理SCM11 企业应…

python DevOps

在云原生中&#xff0c;python扮演的角色是什么&#xff1f; 在云原生环境中&#xff0c;Python 作为一种高级编程语言&#xff0c;在多个方面扮演着重要角色。云原生是指利用云计算的各种优势&#xff08;如弹性、可扩展性和自动化&#xff09;&#xff0c;构建和运行应用程序…

vscode 通过ssh 连接虚拟机vmware(ubuntu)

1.网络连接是否ping的通&#xff08;ubuntu虚拟机使用的是net 连接方式&#xff09; 2.配置环境 ubuntu 需要安装ssh server 服务 &#xff08;1&#xff09;&#xff1a; 安装&#xff08;Ubuntu安装ssh server) apt-get install openssh-server 检查是否ssh server 是否启动…

Hive 常用DML操作

本专栏案例数据集链接: https://download.csdn.net/download/shangjg03/88478038 1.加载文件数据到表 1.1 语法 LOAD DATA [LOCAL] INPATH filepath [OVERWRITE] INTO TABLE</

数据安全的重要性:如何解密[thekeyishere@cock.li].Elbie勒索病毒

尊敬的读者&#xff1a; 随着数字时代的来临&#xff0c;网络威胁也不断进化&#xff0c;而[datastorecyberfear.com].Elbie勒索病毒是其中的一个引人注目的例子。这个恶意软件采用高度精密的方法&#xff0c;将用户的数据文件锁定&#xff0c;并要求支付赎金以获取解锁密钥。…

leetCode 229. 多数元素 II + 摩尔投票法 + 进阶 + 优化空间

229. 多数元素 II - 力扣&#xff08;LeetCode&#xff09; 给定一个大小为 n 的整数数组&#xff0c;找出其中所有出现超过 ⌊ n/3 ⌋ 次的元素。 进阶&#xff1a;尝试设计时间复杂度为 O(n)、空间复杂度为 O(1)的算法解决此问题。 &#xff08;1&#xff09;哈希表 class …