科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][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
题目分析
比较麻烦的一题,首先要用substr截取整数部分,小数部分与指数部分。整数部分的正负号可以一开始用个if语句判断。而根据指数部分的正负,可以分为n>0与n<0两类。
- n<0,指数小于零。那么小数点左移,在开头需要补上零。
- n>=0 指数大等于零。那么小数点右移。这时考虑到指数的大小还有2种情况
1)指数大,需要额外补零。例如-1.2E+10,需要在2后面加9个零。
2)指数小,不需要额外补零。例如+1.23456E+3,此时应该输出1234.56,不需要补零,只需要改变小数点的位置。
代码
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s;
cin>>s;
int i = s.find('E');//返回E在字符串中的下标
string ss = s.substr(1,i-1);//截取E前面的数字,整数+小数部分。
int n = stoi( s.substr(i+1) );//截取E后面的指数部分。
if(s[0]=='-') cout<<'-';
if(n<0)//小数点左移
{
cout<<"0.";
for(int i=0;i<abs(n)-1;i++)
cout<<0;
for(auto x:ss)
if(x!='.') cout<<x;
}
else
{
cout<<ss[0];
int cnt,j;
for(cnt = 0,j = 2;cnt<n && j<ss.length();j++,cnt++ )
cout<<ss[j];
if(j==ss.length())//j走完了,n没走完 。需要额外补零
{
for(int i=0;i<n-cnt;i++) cout<<0;//末尾补上n-cnt个零。
}
else//n走完了,j没走完。不需要额外补零
{
cout<<'.';//先输出个小数点
for(int k= j;k<ss.length();k++)
cout<<ss[k];
}
}
return 0;
}