1024-科学计数法
来源:互联网 发布:男网络主播是干什么的 编辑:程序博客网 时间:2024/05/17 03:36
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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
写得比较水,sscanf用法
#include<cstdio>#include<cstring>int main(){ int i,flag=0,cnt=0,k=0,m; char a[20000]; scanf("%s",a); int len=strlen(a); if(a[0]=='-') printf("-"); for(i=1;i<len;i++) { cnt++; if(a[i]=='E') break; } if(a[cnt+1]=='+') flag=1; char b[len-cnt-2]; for(i=cnt+2;i<len;i++) b[k++]=a[i]; if(flag==0) { sscanf(b,"%d",&m); if(m==1) { printf("0.%c",a[1]); for(i=3;i<cnt;i++) printf("%c",a[i]); } else { printf("0."); for(i=0;i<m-1;i++) printf("0"); printf("%c",a[1]); for(i=3;i<cnt;i++) printf("%c",a[i]); } } else { sscanf(b,"%d",&m); printf("%c",a[1]); if(m<cnt-3) { for(i=3;i<m+3;i++) printf("%c",a[i]); printf("."); for(i=m+3;i<cnt;i++) printf("%c",a[i]); } else { for(i=3;i<cnt;i++) printf("%c",a[i]); int n=m-(cnt-3); while(n--) printf("0"); } } return 0; }
0 0
- 1024 科学计数法
- 1024 科学计数法
- 1024 科学计数法
- 1024 科学计数法
- 1024-科学计数法
- PAT-1024 科学计数法
- PAT 1024科学计数法
- ZJU PAT 1024 科学计数法
- 1024_科学计数法 (20)
- PAT_乙级 1024 科学计数法
- 1024科学计数法 自己写加看答案
- 科学计数法 E
- 科学计数法
- JAVA 科学计数法
- PAT1024 科学计数法
- JAVA科学计数法
- PAT1024科学计数法
- pat_b_1024 科学计数法
- 微信朋友圈录制视频循环播放源码
- 解决微博分享 出现授权界面后直接闪退回自己的APP界面
- HDU 2102 dfs A计划
- SOA 安全概览
- ajax 轮询查询数据
- 1024-科学计数法
- linux学习10练习及答案
- centos 7.0 安装并配置Tomcat
- 浅谈Spring的BeanDefinitionParser的触发流程
- Rxjava2+Retrofit2网络框架傻瓜式接入指南
- http协议Content-Type常见格式
- java多线程和并发面试题整理
- 傅里叶分析之掐死教程(完整版)更新于2014.06.06
- Netty的由来之阻塞I/O模型BIO