PAT乙级1024 科学计数法(C语言)
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [±][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<stdio.h>
int main()
{
char a[10005];
gets(a);//读取科学计数
if(a[0]=='-')//首位为符号输出,正号不管
printf("-");
int i,key;//key记录E的位置
for(i=3;a[i]!='\0';i++)//从小数点后一位开始查找
{
if(a[i]=='E')
{
key=i;
break;
}
}
int sum=0;//求指数的大小
for(i=key+2;a[i]!='\0';i++)
{
sum=sum*10+a[i]-'0';
}
int j=3;
if(a[key+1]=='+')//指数为正时
{
a[0]=a[1];
i=1;
while(sum--)
{
if(j<key)//小数部分
{
a[i++]=a[j++];
}
else//小数部分没有了
{
a[i++]='0';
}
}
if(j<key)//表示小数部分还存在
{
a[i++]='.';
while(j<key)
{
a[i++]=a[j++];
}
}
for(j=0;j<i;j++)
printf("%c",a[j]);
}
else if(a[key+1]=='-')//指数为负时
{
if(sum>=1)
{
printf("0.");
sum=sum-1;
while(sum--)
printf("0");
printf("%c",a[1]);
for(i=3;i<key;i++)
printf("%c",a[i]);
}
else if(sum==0)
{
for(i=1;i<key;i++)
{
printf("%c",a[i]);
}
}
}
printf("\n");
}