PAT乙級1024 科學計數法(C語言)
阿新 • • 發佈:2021-02-15
技術標籤:PAT乙級題
PAT乙級1024 科學計數法(C語言)
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式 [±][1-9].[0-9]+E[±][0-9]+,即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。
現以科學計數法的格式給出實數 A,請編寫程式按普通數字表示法輸出 A,並保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即一個以科學計數法表示的實數 A。該數字的儲存長度不超過 9999 位元組,且其指數的絕對值不超過 9999。
輸出格式:
輸入樣例 1:
+1.23400E-03
輸出樣例 1:
0.00123400
輸入樣例 2:
-1.2E+10
輸出樣例 2:
-12000000000
分析
此處便在提醒我們使用字元陣列來儲存資料;
首先,根據首位字元來判斷需不需要輸出符號
其次,算出指數的大小
然後根據指數的正負來對小數部分進行處理
由此知道輸出時要控制輸出的位數
程式碼
#include<stdio.h>
int main()
{
char a[10005];
gets(a);//讀取科學計數
if(a[0]=='-')//首位為符號輸出,正號不管
printf("-");
int i,key;//key記錄E的位置
for(i=3;a[i]!='\0';i++)//從小數點後一位開始查詢
{
if(a[i]=='E')
{
key=i;
break;
}
}
int sum=0;//求指數的大小
for(i=key+2;a[i]!='\0';i++)
{
sum=sum*10+a[i]-'0';
}
int j=3;
if(a[key+ 1]=='+')//指數為正時
{
a[0]=a[1];
i=1;
while(sum--)
{
if(j<key)//小數部分
{
a[i++]=a[j++];
}
else//小數部分沒有了
{
a[i++]='0';
}
}
if(j<key)//表示小數部分還存在
{
a[i++]='.';
while(j<key)
{
a[i++]=a[j++];
}
}
for(j=0;j<i;j++)
printf("%c",a[j]);
}
else if(a[key+1]=='-')//指數為負時
{
if(sum>=1)
{
printf("0.");
sum=sum-1;
while(sum--)
printf("0");
printf("%c",a[1]);
for(i=3;i<key;i++)
printf("%c",a[i]);
}
else if(sum==0)
{
for(i=1;i<key;i++)
{
printf("%c",a[i]);
}
}
}
printf("\n");
}