1024 科学计数法 (20 分)(c语言)
科學(xué)計(jì)數(shù)法是科學(xué)家用來表示很大或很小的數(shù)字的一種方便的方法,其滿足正則表達(dá)式 [+-][1-9].[0-9]+E[+-][0-9]+,即數(shù)字的整數(shù)部分只有 1 位,小數(shù)部分至少有 1 位,該數(shù)字及其指數(shù)部分的正負(fù)號即使對正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù)?A,請編寫程序按普通數(shù)字表示法輸出?A,并保證所有有效位都被保留。
輸入格式:
每個(gè)輸入包含 1 個(gè)測試用例,即一個(gè)以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù)?A。該數(shù)字的存儲長度不超過 9999 字節(jié),且其指數(shù)的絕對值不超過 9999。
輸出格式:
對每個(gè)測試用例,在一行中按普通數(shù)字表示法輸出?A,并保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400E-03結(jié)尾無空行
輸出樣例 1:
0.00123400結(jié)尾無空行
輸入樣例 2:
-1.2E+10結(jié)尾無空行
輸出樣例 2:
-12000000000結(jié)尾無空行
#include<stdio.h> #include<string.h> #pragma warning(disable:4996) int main() {char A[100000];scanf("%s", A);if (A[0] == '-') putchar('-');int E_pos;for (int cnt = 0; A[cnt] != 'E'; cnt++, E_pos = cnt);char youxiaowei[100000];strncpy(youxiaowei, A + 1, E_pos - 1);youxiaowei[E_pos - 1] = 0;char fuhao = A[E_pos + 1];char temp[100000];strcpy(temp, A + E_pos + 2);int e = atoi(temp);if (fuhao == '-') {if (e == 0) {printf("%s", youxiaowei);}else if (e > 0) {printf("0.");for (int cnt = 1; cnt < e; cnt++) {putchar('0');}youxiaowei[1] = youxiaowei[0];youxiaowei[0] = '.';printf("%s", youxiaowei + 1);}}else{if (e == 0) printf("%s", youxiaowei);else if (e >= E_pos - 3) {youxiaowei[1] = youxiaowei[0];printf("%s", youxiaowei + 1);for (int cnt = 0; cnt < e - E_pos + 3; cnt++) {putchar('0');}}else if (e < E_pos - 3) {for (int cnt = 0; cnt < e; cnt++) {youxiaowei[cnt + 1] = youxiaowei[cnt + 2];youxiaowei[cnt + 2] = '.';}printf("%s", youxiaowei);}}return 0;}我踩過的坑:
strncpy函數(shù)的最后一個(gè)參數(shù)表示從第二個(gè)參數(shù)里復(fù)制多少個(gè)字符,將其賦值到第一個(gè)參數(shù)后不會(huì)在 第一個(gè)參數(shù)的后面加0,所以你得手動(dòng)加,而也有很強(qiáng)的對應(yīng)關(guān)系,第三個(gè)參數(shù)本身就是應(yīng)該添加的0的下標(biāo)位置;
開始把小數(shù)點(diǎn)放在了前面,出現(xiàn)了兩個(gè)0,就00.0……….
這題的第六個(gè)數(shù)據(jù)應(yīng)該非常大,至少我開10000的數(shù)組都不夠,有時(shí)候,你的錯(cuò)誤并不是你的邏輯有問題,而只是程序在轉(zhuǎn)化的過程中出現(xiàn)了錄入錯(cuò)誤等現(xiàn)象,得到的數(shù)組不是我們想要的數(shù)組而導(dǎo)致的錯(cuò)誤,我們可以將數(shù)組開更大來解決這個(gè)問題
總結(jié)
以上是生活随笔為你收集整理的1024 科学计数法 (20 分)(c语言)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 1023 组个最小数 (20 分)(c语
- 下一篇: 1025 反转链表 (25 分)(c语言