1024 科學計數法

2022-02-20 05:31:18 字數 1619 閱讀 6687

部分內容**於:

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

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

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

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

+1.23400e-03
0.00123400
-1.2e+10
-12000000000

以下為引用內容:
思路:首先把情況分為兩大類:

1.指數小於0:例:-1.23e-3,轉為普通數字:-0.00123,指數為3,則小數點後帶2個0,規律如下:設指數為e,小數點後就有e-1個0。

2.指數大於等於0:這個又可以分成兩個情況:

指數長度小於小數:例:+ 1.2345000e + 3,轉為普通數字:1234.5000

指數長度大於小數:例:+ 1.23e + 3,轉為普通數字:1230

這個在乙個迴圈內就能解決:小數點後移e位,e位前如果沒有數值就補0,e位後如果沒有數值了就不加小數點了

% 的意思是:讀入此集合所限定的那些字元。例如 %[a-z] 是指接受大寫字母,一旦遇到非大寫字母便停止接受,而 %[^] 是指不要讀入此集合所限定的那些字元。例如 % [^a-z] 是指不接受大寫字母,一旦遇到大寫字母便停止接受。

填坑日記:陣列一定要設定大一點,我原先容量為10000,測試點5老是通不過,看了好幾遍**我覺得還是沒啥問題,然後把陣列改大一點,就對了。

1 #include2 #include

3using

namespace

std;

4int

main()

5; //

注意這裡和下面三元表示式**的0的區別7//

這裡字元陣列初始化的0是數字08//

但在下面scanf中輸入的0是字元'0'9//

所以才能有下面的 a[i]==0?'0':a[i]

10int

i,e;

11 scanf("

%c%c.%[0-9]e%d

",&h,&a[0],a+1,&e);

12if(h=='-'

)13 printf("-"

);14

if(e<0) //

指數小於0的情況

1523 printf("%s"

,a);24}

25else

//指數不小於0的情況

2633 printf("

%c",a[i]==0?'0'

:a[i]);34}

35}36return0;

37 }

1024 科學計數法

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...

1024 科學計數法

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...

1024 科學計數法

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正規表示式 1 9 0 9 e 0 9 即數字的整數部分只有1位,小數部分至少有1位,該數字及其指數部分的正負號即使對正數也必定明確給出。現以科學計數法的格式給出實數a,請編寫程式按普通數字表示法輸出a,並保證所有有效位都被保留。輸入...