原题链接:http://pat.zju.edu.cn/contests/pat-b-practise/1024
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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>
#include <cstring>
const int N = 10000;
int main()
{
char input[N];
int int_part;
char decimal_part[N];
int exp;
char exp_sign;
while(scanf("%s", input)!=EOF)
{
if(input[0] == '-') {
printf("-");
}
int_part = input[1] - '0';
int size = strlen(input);
int i;
int decimal_len=0;
for(i=3; input[i]!='E' && i<size; i++) {
decimal_part[decimal_len++] = input[i];
}
decimal_part[decimal_len] = 0;
exp_sign = input[++i];
exp = 0;
i++;
for(; i<size; ++i) {
exp = exp*10+(input[i]-'0');
}
if(exp_sign == '+')//指数是正数时的处理分支
{
if(exp>=decimal_len)
{
printf("%d%s", int_part, decimal_part);
while(decimal_len++ < exp) {
printf("0");
}
}
else
{
printf("%d", int_part);
for(i=0; i<exp; i++){
printf("%c", decimal_part[i]);
}
printf(".");
for(; i<decimal_len; i++){
printf("%c", decimal_part[i]);
}
}
}
else
{
if(exp>=1) {
printf("0.");
while(exp>1){
printf("0");
exp--;
}
printf("%d%s",int_part, decimal_part);
}
else {
printf("%d.%s",int_part, decimal_part);
}
}
printf("\n");
}
return 0;
}