⑴ 在c語言中如何指定精確到小數點後任意位數
Note1:
正數 x 四捨五入的技巧:
x --> (int)(x+0.5)
當 x=n+r, 0<=r<1,
若 0<=r<0.5, 則r+0.5<1, (int)(x+0.5)=(int)(n+r+0.5)=n
若 0.5<=r<1, 則1<= r+0.5, (int)(x+0.5)=(int)(n+r+0.5)=n+1
Note2:
舉例來說: 若正數要依捨去法精確到小數點後第二位
x --> (int)(x*100)/100 就好.
例如 3.2794 --> (int)(327.94)/100=327/100=3.27
Note3:
舉例來說: 若正數要四捨五入精確到小數點後第二位
x*100 四捨五入再除以100 就好
也就是 (int)(x*100+0.5)/100
⑵ c語言中小數點後面保留位數,可以怎麼實現
可以在輸出時,指定小數點後的有效位數,實現精確到若干位的效果。
要精確到茄空小數點後若干位,則慶納燃數據類型為浮點型,可能為單精度(float)或雙精度(double)。
在C語言中,使用格式化輸出函數printf來實現輸出。
輸出格式為
%.NF
1 %為格譽虛式化字元串的引導字元。
2 .N表示指定顯示N位小數。
3 F為類型字元,對於float, F值為f, 對於double,F值為lf。
舉例:
1 要輸出float a=1.23234; 保留3位小數的寫法為:
printf("%.3f",a);
2 輸出double b=123.345232; 保留4為小數,寫法為:
printf("%.4lf",b);
⑶ C語言中如何將小數點部分一位一位取出
在輸出時,小數點算做一位.a++不能被賦值,程序有誤,應少寫一個加號,a=a+=5;.十進制-16在計算機里是這么表示的,16的二進制碼是0000000000010000,若要表示-16,則將16的二進制碼取反,得到1111111111101111,再將此數加1,得到1111111111110000,111111110000就是-16在計算機內存中存儲形式,稱為補碼.由於%u表示無符號的整數所以第一位不是符號判斷位,所以他會將補碼認為是一個正整數,所以此二進制值化為十進制是4294967280.所以%u表示-16的值為4294967280.
⑷ 如何用c語言計算小數點後位數
這個要看小數按什麼格式輸入。
如果按%s輸入,也就是按字元串格式輸入,先找到小數點的位置,然後統計下小數點後數字的長度。
具體實現可參考:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char* argv[])
{
char a[128];
while(scanf("%s",a)!=EOF)
{
if(strstr(a,".")!=NULL)
printf("%d\n",strlen(strstr(a,".")+1));
else
printf("0\n");
}
system("pause");
return 0;
}
如果按%f(對應float類型小數)或者%lf(double類型的小數)方式讀入,則需要先去掉整數部分,然後看小數部分一直乘10減去整數部分,知道等於0,統計,乘了幾次10,但是由於浮點數在計算機中存的並不是准確值,這個往往得不到正確的結果。可以使用sprintf(str,"%g",f);,然後由於f畢竟不是准確值,還是會出現有些問題,源碼如下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char* argv[])
{
char a[128];
float f;
while(scanf("%f",&f)!=EOF)
{
sprintf(a,"%g",f);
if(strstr(a,".")!=NULL)
printf("%d\n",strlen(strstr(a,".")+1));
else
printf("0\n");
}
system("pause");
return 0;
}
這是最後一個已經出現錯誤,所以遇到要精確判斷小數點的位數,最好直接按字元串讀入,這和圖靈機的工作原理暗暗相合。
⑸ C語言中如何得到兩數相除的小數點後的數
做除法之前先把任意一個操作數(i 或者 j)強制轉成float類型的就可以了。
比如:
float res;
res = (float)i / j;
⑹ C語言中除法怎麼取得小數
1、打開C-Free,新建文件。
⑺ c語言 去掉小數點後面的數
有兩種方法:
使用函數:
#include<stdio.h>
void main()
{ double x,temp; int a; scanf("%lf",&x);
temp=x; a=int(temp);
while(a!=temp
{ temp=temp*10; a=int(temp);
} printf("%d ",a); }
2.使用強制轉換命令:(int)f;
注意:在轉換的時候,前面的轉換型一定要打括弧,否則不起作用。