博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
1024. 科学计数法 (20)
阅读量:6136 次
发布时间:2019-06-21

本文共 1216 字,大约阅读时间需要 4 分钟。

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

 

#include 
#include
#include
int main(){ char head,ans[10001]= {
0}; int ex; int i; scanf("%c%c.%[0-9]E%d",&head,&ans[0],ans+1,&ex); /* 输入是对其进行拆分,百度出来的极其巧妙的做法 %[] 的意思是:读入此集合所限定的那些字符。 例如 %[A-Z] 是指接受大写字母,一旦遇到非大写字母便停止接受。 而 %[^] 是指不要读入此集合所限定的那些字符。 例如 % [^A-Z] 是指不接受大写字母,一旦遇到大写字母便停止接受。 */ if( head=='-') printf("-"); //如果是负数先输出负号 if( ex>0) {
//如果指数为正的话,小数点后移ex位,ex位前如果没有数值就补0,ex位后如果没有数值了就不加小数点了 for( i=0; i<=ex || ans[i]!=0; i++ ) { if( i==ex+1) printf("."); printf("%c",ans[i]==0? '0':ans[i]); } } else {
//指数为负,小数点前移ex位 printf("0."); for( i=1; i<(-ex); i++) printf("0"); printf("%s",ans); } return 0;}

 

转载于:https://www.cnblogs.com/yuxiaoba/p/8495767.html

你可能感兴趣的文章
java技术团队必须要注意的那几个点
查看>>
Hibernate ORM 5.1.7 发布,数据持久层框架
查看>>
数百万网站因流行 PHP 脚本的安全漏洞而受影响
查看>>
《走进SAP(第2版)》——2.7 SAP对业务流程的支持
查看>>
《C语言解惑》—— 2.9 输出值的操作符
查看>>
Project Volta 让 Android 续航提升了多少?
查看>>
《树莓派实战秘籍》——1.7 技巧07使用过压获得更高的性能
查看>>
《SAS 统计分析与应用从入门到精通(第二版)》一1.4 SAS系统的文件管理
查看>>
《众妙之门——网页设计专业之道》——2.4 总结
查看>>
MySQL sql_mode 说明(及处理一起 sql_mode 引发的问题)
查看>>
Java 注解详解 (annotation)
查看>>
鹰眼跟踪、限流降级,EDAS的微服务解决之道
查看>>
秘籍:程序猿该如何实力撩妹
查看>>
网络编程socket基本API详解
查看>>
API接口设计 OAuth2.0认证
查看>>
Mysql5.6的1755错误解决办法
查看>>
在命令行中运行“mvn compile”因为中文报错
查看>>
Docker的技术不再局限于测试和开发
查看>>
技术干货:工欲善其事,必先利其器 阿里云数据库系列谈之一
查看>>
禁用ViewState
查看>>