简单的模拟,但是需要注意明确三个关键的位置,一个是小数点的位置,一个是E的位置,一个是末尾指数符号的位置,并且要分情况和特殊情况写。
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
using namespace std;
string str;//输入数据的数组
int main(){
getline(cin,str);//直接输入一行
int len=str.length();//获取长度
if(str[0]=='-'){//特判一下符号
cout<<"-";
}
int pos=0;
while(str[pos]!='E'){//获取E的位置
pos++;
}
int exp=0;//存放指数
for(int i=pos+2;i<len;i++){//从E位置往后两个位置开始求和,用秦九昭算法
exp=exp*10+(str[i]-'0');
}
if(exp==0){//特判一下exp为0的情况
for(int i=1;i<pos;i++){
cout<<str[i];
}
return 0;
}
if(str[pos+1]=='-'){//指数是负数
cout<<"0.";
for(int i=0;i<exp-1;i++){//用0补位
cout<<"0";
}
cout<<str[1];//跳过了小数点输出
for(int i=3;i<pos;i++){
cout<<str[i];
}
}
else{//指数为正数
for(int i=1;i<pos;i++){//输出小数点移动之后的数
if(str[i]=='.'){//跳过小数点
continue;
}
cout<<str[i];
if(i==exp+2&&pos-3!=exp){//小数点输出的位置是exp+2,并且小数点和E之间数字的个数pos-3不能等于小数点的右移位数exp(意思就是末尾不输出小数点)
cout<<".";
}
}
for(int i=0;i<exp-(pos-3);i++){//exp比较大,末尾补0;注意如果exp很大,上面i不可能等于exp+2,故不会输出小数点
cout<<"0";
}
}
return 0;
}

403

被折叠的 条评论
为什么被折叠?



