科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][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 <iostream>
#include <string>
#include<algorithm>
#include<bits/stdc++.h>
#include<stack>
#include<set>
#include <vector>
#include <map>
#include<queue>
#include<deque>
#include<cctype>
#include<unordered_set>
#include<fstream>
using namespace std;
int main(){
string s;
cin>>s;
int t=s.find('E');
string s1,s2;
for(int i=0;i<t;i++){//首先分离,E前和E后的字符,E前为数字,E后为位数
s1+=s[i];
}
for(int i=t+1;i<s.size();i++){
s2+=s[i];
}
if(s2[0]=='+'){//加的情况比较多
if(s1[0]=='-'){
cout<<"-";
}
int t=stoi(s2);
int x=s1.find('.');
string ss=s1.substr(x);//ss为小数点后的数字,主要用与统计位数
if(ss.size()==t){//如果小数点后位数与t相等,那么直接输出s1即可,不需要补0什么的,比如-1.2E+01
for(int i=0;i<s1.size();i++){
if(s1[i]!='.'&&s1[i]!='-'&&s1[i]!='+') cout<<s1[i];
}
}
else if(ss.size()<t){//如果小数位数少,那么需要补0,就像测试样例2 那样
for(int i=0;i<s1.size();i++){
if(s1[i]!='.'&&s1[i]!='-'&&s1[i]!='+') cout<<s1[i];
}
for(int i=0;i<=t-ss.size();i++){
cout<<"0";
}
}
else {//如果小数位数多,那么就存在小数点后移的问题,移动的位数就是t的大小
int count=0;//比如-1.231231E+02,输出的是-123.1231,也就是小数点向后移动一位
for(int i=0;i<s1.size();i++){
if(count==x+t+1) cout<<".";//移到位了,输出小数点
if(s1[i]!='.'&&s1[i]!='-'&&s1[i]!='+') cout<<s1[i];
count++;
}
}
}
else{//-的情况很好想,位数是几位就在前面补充对应的0,然后直接输出s1即可,减的情况是很简单的
if(s1[0]=='-') cout<<"-";
cout<<"0.";
for(int i=1;i<abs(stoi(s2));i++){
cout<<"0";
}
for(int i=0;i<s1.size();i++){
if(s1[i]=='.'||s1[i]=='+'||s1[i]=='-') continue;
else cout<<s1[i];
}
}
return 0;
}