这个代码需要化简,
#include<iostream>
using namespace std;
char output[10010];
int lastNumberIndex=-1;
int pointPos=-1;//the index of the last number which before the point
int pow;
bool afterPoint=false;
bool numberPositive=true;
bool powPositive=true;
bool powStart=false;
bool hasShowPoint=false;
int main()
{
char temp;
temp=cin.get();
if(temp=='-')
{
numberPositive=false;
}
while(true)
{
temp=cin.get();
if(powStart==false)
{
if(temp=='E')
{
powStart=true;
continue;
}
if(temp=='.')
{
afterPoint=true;
continue;
}
output[++lastNumberIndex]=temp;
if(!afterPoint)
{
pointPos++;
}
}
else
{
if(temp=='\n')
{
break;
}
if(temp=='-')
{
powPositive=false;
continue;
}
if(temp=='+')
{
continue;
}
pow=pow*10+temp-'0';
}
}
//display
if(!numberPositive)
{
cout<<'-';
}
if(powPositive)
{
for(int i=0;i<=lastNumberIndex;i++)
{
if(i>pointPos)
{
if(pow>0)
{
pow--;
}
else if(!hasShowPoint)
{
cout<<'.';
hasShowPoint=true;
}
}
cout<<output[i];
}
while(pow>0)
{
cout<<'0';
pow--;
}
hasShowPoint=true;
}
else
{
if(pointPos<pow)
{
int diff=pow-pointPos;
cout<<"0.";
hasShowPoint=true;
for(int i=0;i<diff-1;i++)
{
cout<<0;
}
for(int i=0;i<=lastNumberIndex;i++)
{
cout<<output[i];
}
}
else
{
pointPos=pointPos-pow;
for(int i=0;i<=lastNumberIndex;i++)
{
cout<<output[i];
if(i==pointPos&&!hasShowPoint)
{
hasShowPoint=true;
cout<<".";
}
}
}
}
cout<<endl;
}
本文介绍了一个C++程序,该程序用于解析输入的浮点数,并将其按照科学计数法的标准格式进行输出。程序能够正确处理正负号、小数点以及指数部分,同时考虑了不同情况下数值的移动。
343

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



