1. 程式人生 > >PAT.1024. 科學計數法

PAT.1024. 科學計數法

題目

時間限制
100 ms
記憶體限制
65536 kB
程式碼長度限制
8000 B
判題程式
Standard
作者
HOU, Qiming
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式[+-][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

分析:

很典型的模擬題了,我們把它分解來看:
1.實數部分
2.指數部分
對於實數部分,除了有“+”號不輸出以外,其餘全部要保留,唯一區別是根據指數部分的“+”、“-”,把“0”添在實數前面還是添在實數後面
對於指數部分,上面也說了,正負的區別主要是添0的位置,所以我們重點關注它的值
有了大致的思路,我們可以開始了
1.判斷第一個符號,為“+”就跳過,為“-”輸出”-“,
2.設法”儲存”中間的實數部分
3.根據指數的正負,決定添0的前後位置
4.根據指數的大小,再具體決定“.”的位置

程式碼(cpp)

#include<iostream>
using namespace std;
int main(){
    char a[10000+50];
    int k=0;
    int len=0;
    gets(a);
    if(a[k++]=='-')
        cout<<"-";
    int  start=k; 
    while(a[k++]!='E');  
    int end=k-1;  
    for(int i=k+1;a[i]!='\0';i++)
        len = (a[i]-'0')+len*10;
    if
(len==0) for(int i=start;i<end;i++) cout<<a[i]; else if(a[k]=='-'){ cout<<"0."; for(int i=0;i<len-1;i++) cout<<0; for(int i=start;i<end;i++) if(a[i]!='.') cout<<a[i]; } else if(a[k]=='+'){ bool flag = false; for(int i=start;i<end;i++){ if(a[i]!='.') cout<<a[i]; else{ flag = true; continue; } if(flag) len--; if(len==0 && i!=end-1) cout<<'.'; } for(int i=0;i<len;i++) cout<<0; } return 0; }