1014. 科学计数法 (20)

本题的分值只有20分,但在PAT中属于最繁琐的题之一,下面可能是最简短的算法了:

时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小)

题目描述

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分

只有1位,小数部分至少有1位,该数字及其指数部分的正负号即使对正数也必定明确给出。



现以科学计数法的格式给出实数A,请编写程序按普通数字表示法输出A,并保证所有有效位都被保留。

输入描述:

每个输入包含1个测试用例,即一个以科学计数法表示的实数A。该数字的存储长度不超过9999字节,且其指数的绝对值不超过9999。


输出描述:

对每个测试用例,在一行中按普通数字表示法输出A,并保证所有有效位都被保留,包括末尾的0。

输入例子:

+1.23400E-03

输出例子:

0.00123400

#include <stdio.h>
#include <string.h>
int main(){
    char N[10050]="+1.23400E-03";
    int i;
    int p;    
    int e=0;    
    scanf("%s",N);
    p=strchr(N,'E')-N+2;
    for(i=p;i<strlen(N);i++)
        e=e*10+N[i]-'0';    
    if(N[p-1]=='-')
        e *= -1;
    *strchr(N,'E')='\0';
    if(N[0] == '-')
        printf("-");
        
    if(e<0){    
        e *= -1;
        printf("0.");
        for(i=1;i<e;i++)
            printf("0");
        for(i=1;i<strlen(N);i++){
            if(N[i] != '.')
                printf("%c",N[i]);
        } 
    }else if(e<(strlen(N)-3)){
        for(i=1;i<strlen(N);i++){
            if(N[i] != '0')
                printf("%c",N[i]);
            if(i==e+2)
                printf(".");
        }
    }else{
        for(i=1;i<strlen(N);i++){
            if(N[i] != '.')
                printf("%c",N[i]);
        }
        for(i=0;i<e-strlen(N)+3;i++)
            printf("0");
    }    
    return 0;
}

 



posted @ 2017-06-12 09:44  葛杨杨  阅读(270)  评论(0)    收藏  举报