1024 科學計數法 (20 分)

2021-09-03 01:17:29 字數 1154 閱讀 6190

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

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

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

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

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

#include#includeusing namespace std;

int main()

; int i,e;

scanf("%c%c.%[0-9]e%d",&h,&a[0],a+1,&e);

if(h=='-')

printf("-");

if(e<0) //指數小於0的情況

printf("%s",a);

} else //指數不小於0的情況 }

return 0;

}

下面又到我們膜拜大佬的時候了:

**:

#include using namespace std;

int main() else else

}return 0;

}

分析:n儲存e後面的字串所對應的數字,t儲存e前面的字串,不包括符號位。當n<0時表示向前移動,那麼先輸出0. 然後輸出abs(n)-1個0,然後繼續輸出t中的所有數字;當n>0時候表示向後移動,那麼先輸出第乙個字元,然後將t中盡可能輸出n個字元,如果t已經輸出到最後乙個字元(j == t.length())那麼就在後面補n-cnt個0,否則就補充乙個小數點. 然後繼續輸出t剩餘的沒有輸出的字元~

1024 科學計數法 (20 分)

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

1024 科學計數法 (20 分)

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

1024 科學計數法 20 分

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