PAT乙級|C語言|1024 科學計數法 (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

AC代碼

  • 要求有效位被保留。而至於無效的0不去掉也能通過,如下:

輸入

0.001E2

輸出

0001
  • 以下代碼沒有去掉無效位,用了幾個字符串處理函數,也可以自己寫語句實現
#include<stdio.h>
#include<string.h>
int main(){
    char number[20000],*p_int,*p_flo,*p_pow;
    
    gets(number);
    p_int=strtok(number,".");     //字符型整數部分
    p_flo=strtok(NULL,"E"); 	  //字符型小數部分
    p_pow=strtok(NULL,"E");       //字符型指數部分
    int interger,pow;
    interger=atoi(p_int);        //獲得int型整數部分
    pow=atoi(p_pow);			 //獲得int型指數部分
    if(pow>=0){	//指數大於0
        printf("%d",interger);   //輸出整數部分
        int i;
        for(i=0;*p_flo;i++,p_flo++){	//輸出小數部分
            if(i==pow)printf(".");	//相應位置加小數點
			printf("%c",*p_flo);
        }
        while(i<pow){	//補零
        	printf("0");
        	i++;
		}
    }
    else{	//指數小於零
		if(interger<0){  //整數部分小於零
			printf("-");	//輸出負號
			interger=-interger;
		}		   
        pow=-pow;  
        for(int i=0;i<pow;i++){	//小數點前移,補零
            printf("0");
            if(i==0)printf(".");
        }
        printf("%d%s",interger,p_flo);
    }
    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章