1024 科学计数法(C语言详解)
生活随笔
收集整理的這篇文章主要介紹了
1024 科学计数法(C语言详解)
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
前言
這個(gè)題目要考慮挺多小細(xì)節(jié)的(不過(guò)比起福爾摩斯那道還是hhh),我盡力了。。。
正文
題目
科學(xué)計(jì)數(shù)法是科學(xué)家用來(lái)表示很大或很小的數(shù)字的一種方便的方法,其滿(mǎn)足正則表達(dá)式 [±][1-9].[0-9]+E[±][0-9]+,即數(shù)字的整數(shù)部分只有 1 位,小數(shù)部分至少有 1 位,該數(shù)字及其指數(shù)部分的正負(fù)號(hào)即使對(duì)正數(shù)也必定明確給出。
現(xiàn)以科學(xué)計(jì)數(shù)法的格式給出實(shí)數(shù) A,請(qǐng)編寫(xiě)程序按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留。
輸入格式:
每個(gè)輸入包含 1 個(gè)測(cè)試用例,即一個(gè)以科學(xué)計(jì)數(shù)法表示的實(shí)數(shù) A。該數(shù)字的存儲(chǔ)長(zhǎng)度不超過(guò) 9999 字節(jié),且其指數(shù)的絕對(duì)值不超過(guò) 9999。輸出格式:
對(duì)每個(gè)測(cè)試用例,在一行中按普通數(shù)字表示法輸出 A,并保證所有有效位都被保留,包括末尾的 0。輸入樣例 1:
+1.23400E-03輸出樣例 1:
0.00123400輸入樣例 2:
-1.2E+10輸出樣例 2:
-12000000000代碼
#include <stdio.h> #include<string.h> #define MAX 1000 int main(){char s[MAX];int flag=1,num[MAX];//指數(shù)符號(hào)和數(shù)組 int i,len=0,exp=0; int j=0,n;int iBegin=0,iEnd=0;//指數(shù)位起點(diǎn)和終點(diǎn)scanf("%s",s);n=strlen(s);//字符串長(zhǎng)度 if(s[0]=='-') //整數(shù)前的負(fù)號(hào)printf("-");//是符號(hào)就直接輸出for(i=1;s[i]!='E';i++){ if(s[i]!='.'){num[j++]=s[i]-'0';//存儲(chǔ)E前的數(shù)字進(jìn)入數(shù)組 len++;//數(shù)組長(zhǎng)度} }if(s[i+1]=='-'){// E后的符號(hào),指數(shù)的正負(fù) flag=-flag;} iBegin=i+2;//指數(shù)的第一位 iEnd=iBegin;for(iEnd;iEnd<n;iEnd++){exp=exp*10+(s[iEnd]-'0');//存放指數(shù) }/*第一種情況如果指數(shù)是0*/if(exp==0){ for(j=0;j<len;j++)printf("%d",num[j]);//輸出數(shù)組 }/*第二種情況如果指數(shù)是負(fù)數(shù)*/if(flag==-1){printf("0.");while(exp-1){printf("0");exp--;}for(j=0;j<len;j++)printf("%d",num[j]);//輸出數(shù)組 } /*第三種情況如果指數(shù)是正數(shù)*/else if(flag==1){if(exp<len-1) //第三種情況里的第一種情況:如果指數(shù)小于數(shù)組{for(j=0;j<len;j++){printf("%d",num[j]);if(j==exp){printf(".");//輸出小數(shù)點(diǎn) }}} else if(exp>=len-1){//第三種情況里的第二種情況:如果指數(shù)大于等于數(shù)組for(j=0;j<len;j++){printf("%d",num[j]);}while(exp-len+1){printf("0");exp--;}} } }總結(jié)
以上是生活随笔為你收集整理的1024 科学计数法(C语言详解)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Java上传文件到MongoDB Gir
- 下一篇: Node.js+Koa开发微信公众号个人