1024 科學計數法 20 PAT乙級題庫

2021-08-14 01:45:53 字數 1657 閱讀 2070

題面長這樣:

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式[+-][1-9]」.」[0-9]+e[+-][0-9]+,即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。

現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。

輸入格式:

每個輸入包含1個測試用例,即乙個以科學計數法表示的實數a。該數字的儲存長度不超過9999位元組,且其指數的絕對值不超過9999。

輸出格式:

對每個測試用例,在一行中按普通數字表示法輸出a,並保證所有有效位都被保留,包括末尾的0。

輸入樣例1:

+1.23400e-03

輸出樣例1:

輸入樣例2:

-1.2e+10

輸出樣例2:

-12000000000

解法思路:字串分割,輸出也為字串形式,根據冪次計算小數點位置

'''

輸入按字串,由中間的 'e' 分割為 body 和 power 兩部分,

根據10的冪與小數點位數判斷普通數字表示法中小數點的位置,

如果小數點在 body 前面,就補0,如果在後面,就接上0。

'''body, power = map(str, input().split('e'))

if(body[0] == '-'):

print('-',end='')

#獲得小數點位置

for point in range(len(body)):

if(body[1+point] == '.'):

break

power = int(power)

if ( (power+point) <= 0 ): #如果小數點在 body 前面

print("0.",end='')

for i in range(int(power+point), 0):

print('0',end='')

for i in range(1,len(body)):

if(body[i] != '.'):

print(body[i],end='')

else:

count = 0

#count計數輸出 body 中的數字個數

once = true

#解決輸入形如"+0.0e+0"時出現兩個小數點的錯誤

for i in range(1,len(body)):

if(body[i] != '.'):

print(body[i],end='')

count += 1

if(count == power+point) and(count+2!=len(body)) and once:

print('.',end='')

once = false

for i in range(power+point-count): #如果需要在末尾補零

print('0',end='')

#這行用作顯示引數資訊,幫助測試演算法的正確性

#print('\n%s, %d, %d'%(body, power, point) )

1024 科學計數法 20 PAT

時間限制 100 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 hou,qiming 科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數...

PAT乙1024 科學計數法 20

題目在這裡 時間限制 100 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 hou,qiming 科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該...

1024 科學計數法 20 PAT乙級

時間限制 100 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 hou,qiming 科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數...