c語言輸出浮點
1. c語言 輸出浮點數的問題
樓主如果真想弄清楚這個問題的話,建議去看下浮點數的格式.
簡單地說就是,在計算機中,浮點數是表示成類似於十進制中的科學計數法那樣的形式,只不過是表示成a乘以2的b次方,而不是10的b次方,而且a也是2進制數.float有32位,一部分用來表示a,一部分用來表示b,但這部分位數畢竟是有限的,如果a的實際位數超過了這部分的容量,那麼就只能截取掉後面多的位數了,剩下的位數再轉換成10進制數後,肯定和你原來想存的數不一樣了.
存a的這部分我忘了是幾位了,好像是8還是9吧,除去首位有其他用途,後面7位分別表示2的負幾次方,而2的-7次方是0.0078125,所以只能保證小數點後6位是有效的
2. 關於C語言浮點型輸出的簡單問題
10.4f輸出一個浮點數,輸出的總字元數為10(包括小數點),小數點後有四位小數.如果10大於你要輸出的數字字元數,則前面補空格,否則按原數輸出.
如果你想讓不足時不0,你可以寫成%010.4f
6.2f差不多
3. C語言怎麼能把字元串轉化成浮點型數據
使用atof函數。
一、描述:
C 庫函數 double atof(const char *str) 把參數 str 所指向的字元串轉換為一個浮點數(類型為 double 型)。
二、atof() 函數的聲明:
double atof(const char *str)。
三、參數:
str -- 要轉換為浮點數的字元串。
四、返回值:
函數返回轉換後的雙精度浮點數,如果沒有執行有效的轉換,則返回零(0.0)。
實例演示代碼:
4. c語言輸出浮點數
因為你冒泡排序的時候,數值交換中間變數temp你定義的是int型。
而你結構成員ave是浮點型,當浮點轉int時,小數位就丟失了。之後你再把int轉給浮點,自然小數位就是0了。。。
5. C語言單精度浮點型的輸出
程序在處理浮點數精度的問題過程中,由於浮點數在內存里是按2進制存儲的。它的有效數值在小數點後的6-7位,輸出過程中會有偏差,所以一般來說輸出浮點數都要指定精度,比如:
printf("%.3f\n",g);
在%f前面加.3表示小數點後保留3位,同樣%2.3f可以在整數位保留2位的同時小數也保留3位。
6. C語言中,輸出浮點數時保留兩位小數應該怎麼搞
需要准備的材料分別有:電腦、C語言編譯器。
1、首先,打開C語言編譯器,新建一個初始.cpp文件,例如:test.cpp。
7. C語言中printf輸出浮點數按"%m.nf"格式輸出,為什麼有的會四捨五入,而有的沒有
首先肯定,電腦一定會四捨五入;
其次解釋,為什麼119.985四捨五入後成為了119.98了,因為計算機內部是二進制,某些看似簡單小數轉換為二進制會許多位、甚至循環,所以再次轉換為十進制的時候可能產生誤差,119.985這么一折騰有可能就成為了119.984999999,因此出現帖子的情況。
作為驗證,我在UNIX平台寫了一個簡單的程序,程序代碼和執行過程如下圖:
8. C語言輸出 浮點型數據輸出
##include<stdio.h>
intmain(intargc,char**argv)
{
doublet;
ints,m;
scanf("%d",&m); //占的位數,這個你可以不要
printf("保留小數位數:");
scanf("%d",&s);
printf("輸入數據:");
scanf("%lf",&t);
printf("%*.*lf
",m,s,t);//就小數的話就寫"%.*lf
"
return0;
}
9. C語言 怎樣將無符號整型轉換成浮點型
C語言中無符號整型轉換成浮點型方法如下:
unsigned
int
x=123;
1、輸出強制轉換,如:
printf("%f",
x
);
//這樣的輸出因為%f與x的類型不同,導致輸出數據異常
printf("%f",
(float)x
);
//強制轉換成浮點型,可正確輸出
2、存儲到相應的變數中,如:
float
fVal;
fVal=x
;
//系統會隱式轉換
因float的有效數位最大為7位,所以,並不是所有整數都可以用float類型變數來表示,所以,最好使用double類型來存儲任意的整數
printf("%f",
fVal
);
//輸出正常
double
dVal;
dVal=x
;
//系統會隱式轉換
printf("%f",
dVal
);
//輸出正常
10. C語言浮點數輸出
#include<stdio.h>
intmain()
{
doublef;
scanf("%lf",&f);
inti=f*10000;
i=i/10+i/10%5;
f=(double)i/1000;
printf("%f",f);
return0;
}