1. 程式人生 > >PAT乙級(Basic Level)真題-1014 科學計數法 (20)

PAT乙級(Basic Level)真題-1014 科學計數法 (20)

科學計數法 (20)

時間限制 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 <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <string>
#include <cstdlib>
#include <stack>
#include <map>
#include <set>
#include <queue>
using namespace std;
const int maxn = 1e5+100;
char s[maxn];
int main(void)
{
    cin>>s;
    int flag=0;
    int len = strlen(s);
    if(s[0]=='+') flag=1;
    int num2=0;
    int p=0;
    int mark_E=0;
    for(int i=0;i<len;i++)
    {
        if(s[i]=='E')
        {
            mark_E=i;
            if(s[i+1]=='+') p=1;
            for(int j=i+2;j<len;j++)
                num2=num2*10+s[j]-'0';
            break;
        }
    }
    if(flag==0) printf("-");
    if(num2==0)
    {
        for(int i=1;i<mark_E;i++)
            printf("%c",s[i]);
        return 0;
    }
    if(p==1)//+
    {
        int cnt=0,i;
        printf("%c",s[1]);
        for(i=3;i<mark_E;i++)
        {
            printf("%c",s[i]);
            cnt++;
            if(cnt==num2)
            {
                printf(".");
                continue;
            }
        }
        for(;cnt<num2;cnt++)
            printf("0");
    }
    else //-
    {
        int cnt=1,i;
        printf("0.");
        for(int i=1;i<num2;i++)
            printf("0");
        for(i=1;i<mark_E;i++)
        {
            if(s[i]=='.') continue;
            printf("%c",s[i]);
        }
    }
    puts("");
    return 0;
}