题目
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].
[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指数部分的正负号即使对正数也必定明确给出。
现以科学计数法的格式给出实数 A,请编写程序按普通数字表示法输出 A,并保证所有有效位都被保留。
输入格式:
每个输入包含 1 个测试用例,即一个以科学计数法表示的实数 A。该数字的存储长度不超过 9999 字节,且其指数的绝对值不超过 9999。
输出格式:
对每个测试用例,在一行中按普通数字表示法输出 A,并保证所有有效位都被保留,包括末尾的 0。
分析
题目不难。
将整个字符串分成了 : sig1 , zheng , dot , xiao , E , sig2 , zhi
正负号, 整数部分, 小数点, 小数部分 , E字符,第二个正负号, 指数部分
(1)字符串分割。
建议自己以后使用字符串的find 和 substr函数综合起来。
(2)注意-1.23E+2 这种,可能会输出成-123. 多了个小数点。重写了一遍才发现这个小错误,可能涉及到了两个测试点。
(3) 指数部分是0 的, 我单独拎出来考虑了。
(4) 注意小数点的输出和小数部分的输出 在 For 循环里面的顺序
代码
#include<iostream>
#include<algorithm>
#include<string.h>
#include<cstring>
#include<stack>
using namespace std;
int main()
{
char sig1;
int zheng;
char dot;
string tmp;
string xiao;
char E;
char sig2;
int zhi = 0;
cin >> sig1 >> zheng >> dot >> tmp;
int posE = tmp.find('E');
E = tmp[posE];
sig2 = tmp[posE + 1];
xiao = tmp.substr(0 , posE);
string zhitmp = tmp.substr(posE + 2 , tmp.length());
for(int i = 0 ; i < zhitmp.length() ; i ++)
{
zhi *= 10;
zhi += int(zhitmp[i] - '0');
//cout << "zhi: " << zhi <<endl;
}
//cout << sig1 << zheng << dot << xiao << E << sig2 << zhi <<endl;
if( sig1 == '-') cout << sig1;
if( zhi == 0 )
{
cout << zheng << dot << xiao ;
return 0;
}
if ( sig2 == '+')
{
cout << zheng ;
for (int i = 0 ; i < xiao.length() ; i++)
{
cout << xiao[i];
if( 1 + i == zhi && i != xiao.length() - 1)
{
cout << dot ;
}
}
if( xiao.length() < zhi)
{
zhi -= xiao.length();
while( zhi -- ) cout << 0;
}
}
else if ( sig2 == '-')
{
cout << "0." ;
while( --zhi )
cout << 0;
cout << zheng << xiao;
}
}