1024 科学计数法 (20 分)(c语言)
生活随笔
收集整理的這篇文章主要介紹了
1024 科学计数法 (20 分)(c语言)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表達式 [+-][1-9].[0-9]+E[+-][0-9]+,即數字的整數部分只有 1 位,小數部分至少有 1 位,該數字及其指數部分的正負號即使對正數也必定明確給出。
現以科學計數法的格式給出實數?A,請編寫程序按普通數字表示法輸出?A,并保證所有有效位都被保留。
輸入格式:
每個輸入包含 1 個測試用例,即一個以科學計數法表示的實數?A。該數字的存儲長度不超過 9999 字節,且其指數的絕對值不超過 9999。
輸出格式:
對每個測試用例,在一行中按普通數字表示法輸出?A,并保證所有有效位都被保留,包括末尾的 0。
輸入樣例 1:
+1.23400E-03結尾無空行
輸出樣例 1:
0.00123400結尾無空行
輸入樣例 2:
-1.2E+10結尾無空行
輸出樣例 2:
-12000000000結尾無空行
#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函數的最后一個參數表示從第二個參數里復制多少個字符,將其賦值到第一個參數后不會在 第一個參數的后面加0,所以你得手動加,而也有很強的對應關系,第三個參數本身就是應該添加的0的下標位置;
開始把小數點放在了前面,出現了兩個0,就00.0……….
這題的第六個數據應該非常大,至少我開10000的數組都不夠,有時候,你的錯誤并不是你的邏輯有問題,而只是程序在轉化的過程中出現了錄入錯誤等現象,得到的數組不是我們想要的數組而導致的錯誤,我們可以將數組開更大來解決這個問題
總結
以上是生活随笔為你收集整理的1024 科学计数法 (20 分)(c语言)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 1023 组个最小数 (20 分)(c语
- 下一篇: 1025 反转链表 (25 分)(c语言