1024 科学计数法 (20分)
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][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
思路
- 先用进行切分,分别处理系数和指数字段。
切分用到的
p=strchr(n,'E');
功能是用p指向E字符所处的地址,然后p++指针后移完成后半段切分;注意再p++前可以利用p确定前半段,通过strncpy(a,n,len-strlen(p));
把字符串n的长度为len-strlen§的前半段 存到字符串a中。
- 之后的事情就是进行运算了。
有一个后半段字符串转常数的技巧----使字符串流对象进行数字转换。通过
#include<sstream>
库中的函数:istringstream str1(p); ostringstream ostr; str1>>y;
来实现将指数变成常数。
运算过程注意区分指数的正负,以及系数的正负,还有小数点的移动情况,例如小数点右移时要考虑小数点不再打印只打印0的情况。
- 最后记得while读入的底部字符串要清空格式化,以免影响下一次读入。
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<vector>
#include<queue>
#include<sstream>
using namespace std;
int main(){
#ifdef ONLINE_JUDGE
#else
freopen("in.txt","r",stdin);
#endif
char n[20021],*p,a[10010],b[10010];
int len,i,x,y;
memset(a,'\0',sizeof(a));
while(cin.getline(n,20021))
{
len=strlen(n);
p=strchr(n,'E');
strncpy(a,n,len-strlen(p)); ++p;
istringstream str1(p);
ostringstream ostr;
str1>>y;
if (y==0)
{
if(a[0]=='-')cout<<a[0];
for(i=1;i<strlen(a);i++)cout<<a[i];
cout<<endl;
}
else if(y>0)
{
if(a[0]=='-')cout<<a[0];
cout<<a[1];
if(strlen(a)-3>y)
{
for(i=3;i<y+3;i++)cout<<a[i];
cout<<'.';for(i;i<strlen(a);i++) cout<<a[i];
}else{
for(i=3;i<strlen(a);i++)cout<<a[i];
for(i;i<y+3;i++)cout<<'0';
}
cout<<endl;
}else if(y<0)
{
if(a[0]=='-')cout<<a[0];
printf("0.");
for(i=0;i<(-1*y)-1;i++)cout<<'0';
cout<<a[1];
for(i=3;i<strlen(a);i++)cout<<a[i];
cout<<endl;
}
memset(a,'\0',sizeof(a));
memset(b,'\0',sizeof(b));
memset(p,'\0',sizeof(p));
memset(n,'\0',sizeof(n));
}
return 0;
}