科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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
用C写程序需要了解非常多的库函数。
在这里利用了strchr函数。(查找字符串s中首次出现字符c的位置,返回首次出现c的位置的指针,如果s中不存在c则返回NULL。)
atoi()函数(将字符串转化为整型数字)
再者就是要区分小数部分的正负号和指数部分的正负号。以及小数点移动的位数。
代码很长,边写边调试出来的,以后有时间可以修改一下。
#include<stdio.h>
#include<string.h>
#include <stdlib.h>
int main()
{
char s[20000],rnt[20000] ;
char *f;
int w,i,j;
gets(s);
f=strchr(s,'E');
f[0]='\0';
f++;
w=atoi(f);
if(w<0)
{
w=-w;
if(s[0]=='+')
{
rnt[0]='0';
rnt[1]='.';
for(i=2;i<=w;i++)
{
rnt[i]='0';
}
for(j=0;s[j]!='\0';j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
}
if(s[0]=='-')
{
rnt[0]='-';
rnt[1]='0';
rnt[2]='.';
for(i=3;i<=w+1;i++)
{
rnt[i]='0';
}
for(j=0;s[j]!='\0';j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
}
}
else
{
if(s[0]=='+')
{
rnt[0]=s[1];
for(i=1,j=3;s[j]!='\0'&&i<=w;j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
if(i>w)
{
if(s[j]!='\0')
{
rnt[i++]='.';
}
for(;s[j]!='\0';j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
}
if(s[j]=='\0')
{
for(;i<=w;i++)
{
rnt[i]='0';
}
}
}
if(s[0]=='-')
{
rnt[0]='-';
rnt[1]=s[1];
for(i=2,j=3,w++;s[j]!='\0'&&i<=w;j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
if(i>w)
{
if(s[j]!='\0')
{
rnt[i++]='.';
}
for(;s[j]!='\0';j++)
{
if(s[j]>='0'&&s[j]<='9')
{
rnt[i]=s[j];
i++;
}
}
}
if(s[j]=='\0')
{
for(;i<=w;i++)
{
rnt[i]='0';
}
}
}
}
rnt[i]='\0';
printf("%s",rnt);
return 0;
}