科学计数法是一种数学专用术语。将一个数表示成 a×10的n次幂的形式,其中1≤|a|<10,n为整数,这种记数方法叫科学计数法。例如920000可以表示为9.2*10^5
现在需要对输入的字符串进行分离,自动识别该科学计数法中的a和幂次,计算其表征的具体数值并输出该值。
注意:
1、每组测试数据仅包括一个用于科学计数法的字符串。
2、输入字符串保证合法。
3、字符串长度不超过1000
4、幂次不超过200
输入示例:
9.2*10^5
输出示例:
The actual value for 9.2*10^5 is 920000
分析:a 、n 都可以为负数,幂次可以达到上百故要用string处理。
AC代码:
#include<bits/stdc++.h>
using namespace std;
string s;
int main()
{
cin>>s;
string old=s;//old保存初始字符串
string res="";//res为结果字符串
if(s[0]=='-')
res="-",s=s.substr(1);//substr(1)表示从下标为1的字符取到最后的子串
//find("*")表示从前往后,如果查找成功,返回*第一次出现的下标
//s1.find(s2,pos)表示从pos下标开始找s2,s1.rfind(s2,pos)表示从后往前找
int pos=s.find("*");
string t=s.substr(0,pos); //substr(0,pos)返回从0开始的pos个字符组成的字符串
if(s[1]=='.')
t.erase(1,1);//删除从1开始的1个字符即删除下标为1的字符'.'
pos=s.find("^");
int x=stoi(s.substr(pos+1));//stoi即string to int字符串转整型
if(x>=0)
{
if(t.size()>x+1) res+=t.substr(0,x+1)+"."+t.substr(x+1);
else res+=t+string(x-t.size()+1,'0');
//string(x-t.size()+1,'0')表示构造x-t.size()+1个0的字符串
}
else
{
res+="0."+string(-x-1,'0')+t;
}
printf("The actual value for %s is %s",old.c_str(),res.c_str());
//c_str()函数表示将C++风格的字符串转成C风格的字符串,这样才能用printf
return 0;
}