1024 科學(xué)計(jì)數(shù)法 (20 分)

科學(xué)計(jì)數(shù)法是科學(xué)家用來表示很大或很小的數(shù)字的一種方便的方法,其滿足正則表達(dá)式 [+-][1-9].[0-9]+E[+-][0-9]+,即數(shù)字的整數(shù)部分只有 1 位,小數(shù)部分至少有 1 位,該數(shù)字及其指數(shù)部分的正負(fù)號即使對正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù) A,請編寫程序按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即一個以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù) A。該數(shù)字的存儲長度不超過 9999 字節(jié),且其指數(shù)的絕對值不超過 9999。
輸出格式:
對每個測試用例,在一行中按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400E-03
輸出樣例 1:
0.00123400
輸入樣例 2:
-1.2E+10
輸出樣例 2:
-12000000000

代碼:

//有個非常關(guān)鍵的一點(diǎn)就是在PAT里面gets()函數(shù)只能在純C的條件下運(yùn)行
//另外一點(diǎn)就是利用printf()輸出字符串的時(shí)候,雙引號里面是%c不是%s,如果使用了%s,程序?qū)o法輸出任何字符 
#include<stdio.h> 
#include<string.h>

int main(){
    char a[10000];
    int poE,zs=0,temp=1;//poE保存了E的位置 ;zs保存了后面的指數(shù)是多少 ;temp用來輸出zs 
    gets(a);
    int len=strlen(a);//len保存了輸入字符串的長度
    if(a[0]=='-'){
        printf("-");
    }
    for(int i=0;i<len;i++){//找到E在數(shù)組之中的位置 
        if(a[i]=='E'){
            poE=i;
        }
    }
    for(int i=len-1;i>=poE+2;i--){//計(jì)算出指數(shù)zs 
        zs+=(a[i]-'0')*temp;
        temp*=10;
    }
    
    if(a[poE+1]=='+'){//如果指數(shù)是正號 
        printf("%c",a[1]);//把小數(shù)點(diǎn)前面那個數(shù)先輸出
        if(zs>=(poE-3)){//如果指數(shù)已經(jīng)超出小數(shù)的范圍 
            for(int i=3;i<poE;i++){
                printf("%c",a[i]);//把小數(shù)點(diǎn)后面的數(shù)字輸出 
            }
            int k=zs-poE+3;
            while(k--){//持續(xù)輸出后面的0 
                printf("0");
            }
        } 
        else{//如果指數(shù)不夠大讓前面的數(shù)字乘以足夠多的10 
            for(int i=3;i<=2+zs;i++){
                printf("%c",a[i]);
            }
            printf(".");//輸出小數(shù)點(diǎn)
            for(int i=3+zs;i<=poE-1;i++){
                printf("%c",a[i]);
            } 
        }
    }
    if(a[poE+1]=='-'){//如果指數(shù)是負(fù)號 
        printf("0.");
        for(int i=0;i<zs-1;i++){
            printf("0");
        } 
        printf("%c",a[1]);
        for(int i=3;i<=poE-1;i++){
            printf("%c",a[i]);
        }
    }
    
    return 0;
} 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容