科学计数法
来源:互联网 发布:压缩视频的软件 编辑:程序博客网 时间:2024/04/28 02:43
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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 <iostream>#include <cstdio>#include <algorithm>#include <cstring>using namespace std;// +1.23400E-03 0.00123400//-1.2E+10 -12000000000int main(){char a[10050];scanf("%s",a);//字符串是从0开始标号的,所以最后一位下标是len-1int n = strlen(a)-1;//如果输入的为负数,那么开始就输出负号if(a[0]=='-')cout << "-";//e代表的是E后面的数字是多少,是为了确定小数点//要移动多少位,在这里采用的是倒着算(e表示)int e = 0,t = 1;//e表示E之后的数字为多少while(a[n]!='+'&&a[n]!='-'){e+=t*(a[n]-'0');t*=10;n--;}if(a[n]=='-')e*=-1;t=0;cout << a[n-1] << endl;if(e == 0){for(int i = 1;i < n-1;i++)cout << a[i];}else if(e < 0){e*=-1;cout << "0.";for(int i = 1;i < e;i++)cout << "0";for(int i = 1;i < n-1;i++)if(a[i]!='.')cout << a[i];}else{for(int i = 1;i < n-1;i++){if(a[i] != '.'){cout << a[i];t++;}if((t-1==e) && (t != n-3))cout << ".";} while(t <= e) { cout << "0"; t++; }}return 0;}
阅读全文
0 0
- 科学计数法 E
- 科学计数法
- JAVA 科学计数法
- PAT1024 科学计数法
- JAVA科学计数法
- PAT1024科学计数法
- pat_b_1024 科学计数法
- 1024 科学计数法
- C++科学计数法
- 科学计数法
- java科学计数法
- poi_科学计数法
- 1024 科学计数法
- 1024. 科学计数法
- 1024. 科学计数法
- PAT1024科学计数法
- 1024. 科学计数法
- 科学计数法
- itext7学习笔记——第2章实践&example
- 使用maven命令,安装jar包到本地maven仓库
- SSH开发常用注解
- 几个第三方Java串口库
- 删除链表中倒数第n个节点
- 科学计数法
- django 、celery 中logging的使用
- [HDU](1233)还是通畅工程 ---最小生成树(图)
- 【学习笔记】无限极分类显示优化
- 高级排序算法(二)
- php使用PDO从数据库表中读取数据
- 分享一些QQ常用的WEB接口(新)
- POJ
- Android Studio 制作简易计算器