1024. 科学计数法 (20)
时间限制 100 ms
内存限制 65536 kB
代码长度限制 8000 B
判题程序 Standard
作者 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
原题地址: https://www.patest.cn/contests/pat-b-practise/1024
这道题刚开始没有看清楚,因为整数部分可以是0,,自己弄麻烦了,导致最后两个test没有过,今天看了别人的代码才明白,但也是测试了好久才过。
计算出小数部分的位数分清楚情况可以了
#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;
char str[10000];
void solve()
{
char num[10000] = {0}; //去掉小数点后的数字串
int len = strchr(str, 'E') - str - 3; //小数部分长度
num[0] = str[1];
strncpy(num + 1, str + 3, len);
int ex = atoi(str + len + 4); //获取指数
int pos = 1; //小数点位置
if(str[0] == '-')
cout << '-';
if(ex > 0){
pos += ex;
if(len < ex){
cout << num;
for(int i = len; i < ex; i ++)
cout << '0';
}
else if(len > ex){
for(int i = 0; i < pos; i ++)
cout << num[i];
cout << '.';
for(int i = pos; i < len + 1; i ++)
cout << num[i];
}
else{
cout << num;
}
}
else if(ex < 0)
{
cout << "0.";
for(int i = ex + 1; i < 0; i ++){
cout << '0';
}
for(int i = 0; i < len + 1; i ++)
cout << num[i];
}
else{
for(int i = 0; i < pos; i ++)
cout << num[i];
cout << '.';
for(int i = pos; i < len + 1; i ++)
cout << num[i];
}
cout << endl;
}
int main()
{
cin >> str;
solve();
return 0;
}