c語言四捨五入嗎
Ⅰ c語言中有四捨五入的概念嗎
C語言中有四捨五入的概念的。
實數輸出時,多餘的小數部分,是自動四捨五入進行的
Ⅱ c語言中如何進行四捨五入,求詳細解釋!!謝謝!
方法一:
#include<stdio.h>
int main()
{
double d1,d2,d3;
d1=-3.1415926;
d2=(int)(d1*10+0.5)*0.1;
printf("d1=%f,保留一位小數的結果為:%.1f ",d1,d2);
d3=(int)(d1*1000+0.5)*0.001;
printf("d1=%f,保留三位小數的結果為:%.3f",d1,d3);
總結四捨五入保留n為小數
(int)(x*10的n次方+0.5)*10的負n次方;
其次這個方法對負數無效;如果非要用可以先取正數部分算,最後加上負號
}
方法二:
使用round()函數。
#include"stdio.h"
#include"math.h"
void main()
{
float x;
scanf("%f",&x);
int y = round(x);
printf("%d",y);
}
(2)c語言四捨五入嗎擴展閱讀:
C語言編寫注意事項:
1、%運算符不能應用與float或double類型。
2、char類型轉換為int型時, 無法判斷它是signed還是unsigned.這樣其結果有可能為負數, 因此轉換時盡量指定signed和unsigned限制符。
3、++i與i++不同之處: ++i是先+1在使用, i++是先使用i在遞加1。
4、三元運算符"?:" 第一個表達式的括弧不是必須的,但是由於三元表達式的優先順序非常低,我們還是將第一個表達式用()括起便於閱讀和理解。
5、C語言中可以使用遞歸 (即函數調用自身函數), 其不節省儲存器開銷也不加快執行速度, 只是使程序緊湊便於理解。
Ⅲ 關於C語言中小數是否有四捨五入
C的四捨五入是大於5就進位,否則就不進位。
你後面的那個程序是123.4567中
5後面有個6,在四捨五入時,6大於5則進位,然後5變成6,同樣也進位。
測試一下,你把數據改成123.455,我沒有試過,你試一下。呵呵。
Ⅳ c語言四捨五入是怎樣的
全舍不入
需要實現四捨五入的時候就要使用double或者float類型的數進行運算然後if判斷
http://..com/question/68502540.html剛好有個類似的問題
Ⅳ c語言中的四捨五入怎麼做
利用取整運算的截斷特點實現。
比如:int a=0.75;取整後賦值給a的是0,小數點後面的被截斷了。
如果要做整數的四捨五入,那麼可以:a=(int)(0.75+0.5);取整後得到的與數學中四捨五入的結果一致,都是1;
如果要進行小數點後面的四捨五入,可以這樣計算:
要保留小數點後面兩位的小數,即在小數點後面兩位上做四捨五入,0.756
float a=0.756,b; int x; b=a*100; b+=0.5; x=b; b=x/100;
運算是這樣的:先將0.756乘以100,得到75.6,然後利用取值運算的截斷做四捨五入,75.6+0.5=76.1取整後等於76,再除以100,得到結果:0.76
Ⅵ C語言怎麼四捨五入
利用取整。
比如 四捨五入到千分位,可以
(int)(x*1000+0.5)/1000.0
十分位(int)(x*10+0.5)/10.0
其他類似,只改變其中倍數的值即可。
Ⅶ c語言中怎麼四捨五入
設 float x ; int y ; 則有y=(int)(x+0.5)>(int)x?(int)x+1:(int)x進行上述運算後,y 的值就是 x 四捨五入的結果。
Ⅷ C語言有沒有數據的四捨五入什麼情況下會用到四捨五入數據類型轉換
C語言中的float和double類型數據是浮點數,所以小數部分就存在四捨五入問題,當指定輸出位數在精度范圍之內時,系統會自動舍入,無需人工干預,如果小數部分也在精度范圍內,比如10.0/2.0 = 5.0,2位以上的輸出位數時,後面的都是0,此時,當然不需要舍入了。
數據類型轉換有兩種方式,一種是默認強制轉換,比如將char、short、Int、Long和float類型數據賦給double類型變數時,編譯程序會自動實施轉換,這是因為,在精度更高時,這樣的轉換是內有損失的。另一種是手動強制類型轉換,比如dnum = (double)inum;,意思是將整形變數inum首先轉換為雙精度數據,然後再付給dnum。當將高精度類型變數賦給低精度類型變數時,除非手動強制轉換,否則,編譯程序會有提示的。
Ⅸ 四捨五入c語言
如果只是要求輸出結果「四捨五入」,只要通過輸出格式符控制即可。
例如:
double pi=3.1415926;
printf("%.4lf\n",pi);
可得輸出為3.1416。
printf("%.2lf\n",pi);
可得輸出為3.14。
如果是要把變數本身的值四捨五入到4位小數,則可以這樣處理:
double pi=3.1415926;
pi=((int)(pi*10000+0.5))/10000.0;
Ⅹ c語言怎麼實現四捨五入
# incloud <stdio>
int main(void)
{
float a ;
scanf(「%f」,&a);
a=(int)(a*1000+0.5)/1000.0;
printf (「%0.3f」,a);
return 0;
}
(10)c語言四捨五入嗎擴展閱讀:
其他方法實現四捨五入:
int myround(double indata,int precision,double * outdata)
{
long pre = 1,i;
for(i = 0; i <precision; i ++)pre = pre * 10;
if(cy_FloatCompare(indata,0.00)> 0)
* outdata =(int)((indata * pre)+0.5)/100.00;
else
* outdata =(int)((indata * pre)-0.5)/100.00;
return 0;
}
// cy_FloatCompare是浮點數與0比較的函數,假設它存在。返回值與strcmp相同。