1024. 科学计数法 (20)
来源:互联网 发布:不锈钢交易网软件 编辑:程序博客网 时间:2024/05/24 05:03
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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 <bits/stdc++.h>using namespace std;struct node { int aval; string bval; int blen; int cval;};int main(){ string s; string result = ""; cin >> s; node k; //得到.之前的整数 k.aval = s[1]-'0'; int Eindex = 0; for (int i = 2; i < s.length(); i++) { if (s[i] == 'E') { Eindex = i; break; } } //得到.之后E之前的小数 string bval = s.substr(3, Eindex-3); k.bval = bval; k.blen = k.bval.length(); //得到E之后的指数 string cval = s.substr(Eindex+2, s.length()-Eindex-1-1); char op[10]; for (int i = 0; i < cval.length(); i++) op[i] = cval[i]; k.cval = atoi(op); //output; int zeronum = 0;//计算前面的0的个数或者后面的0的个数 if (s[0] == '-') cout << "-";//是负数要输出"-" //前面的0 if (s[Eindex+1] == '-') { if (k.cval == 0) cout << k.aval << "." << k.bval << endl; else { cout << "0" << "."; for (int i = 1; i < k.cval; i++) cout << "0"; cout << k.aval; cout << k.bval << endl; } } else { //后面的0 if (k.cval < k.bval.length()) { cout << k.aval; //先输出k.cval个 bval中的字符,然后输出个".",然后把剩余的输完 for (int i = 0; i < k.cval; i++) cout << k.bval[i]; cout << "."; for (int i = k.cval; i < k.bval.length(); i++) cout << k.bval[i]; cout << endl; } else {//如果k.vcal大于k.bval的长度,说明将不输出"." cout << k.aval; cout << k.bval; zeronum = k.cval - k.bval.length(); for (int i = 0; i < zeronum; i++) cout << "0"; cout << endl; } } return 0;}
阅读全文
0 0
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)
- [HAOI2016]食物链
- 正则表达式简介及学习网址、测试网址
- esri-leaflet入门教程(4)-加载各类图层
- 以太坊研究课题
- 波士顿动力机器人“体力不支”,搬箱子不成反摔倒
- 1024. 科学计数法 (20)
- java版线段树(HDU1166)
- oVirt Integration ceph
- 如何解决create view中Select where语句中含有中文不能生成视图记录的问题
- Http协议
- Mybatis一级缓存 去除
- 开机自启动activity或service
- 编译测试MATLAB版本的faster rcnn和rfcn
- spring-boot 允许接口跨域并实现拦截