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,並保證所有有效位都...