PAT乙級1024(C語言)-科學計數法 (20)

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表達式[+-][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<bits/stdc++.h>
using namespace std;

int main(void)
{
    char head,a[10001]= {0};
    int ex=0;
    scanf("%c%c.%[0-9]E%d",&head,&a[0],a+1,&ex);//輸入拆分
    if (head == '-') printf("-");
    if(ex>=0)
    {
        for(int i=0; i<ex+1||a[i]!=0; i++)
        {
            if(i==ex+1) printf(".");
            printf("%c",a[i]==0?'0':a[i]);
        }
    }
    else
    {
        printf("0.");
        for(int i=1; i<(-ex); i++)
            printf("0");
        printf("%s",a);
    }
    printf("\n");

    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章