⑴ 整型和浮點型數據1 2.123等於多少
結果肯定是浮點型數據。因為浮點型數據屬於所謂「高類型」(比整型高),而整型數專據屬於「低屬類型」。計算機語言中數據類型的轉換有自動和強制兩種方式,浮點型數據加整型數據符合自動轉換規范。自動轉換規則是「低類型」數據向「向類型」數據看齊,即一個浮點數加一個整型數,是要將整型數自動變為浮點數來求和的,結果當然是浮點型數據……
⑵ 整型和浮點型相減的問題
printf("%lf",double(12)-int(12));
有結果,是12.0.
double的12就是12.0
解釋為什麼是死循環-
浮點數是二進制存儲,而精確的浮點二進制存儲為,整數是2的+n次方的算術和,小數是2的-n次方的算術和.例如0.5、0.25、0.125此類小數可以精確表示,而諸如0.1、0.17這類小數就有誤差,具體體現在浮點數的位數波動,實際的存儲值可能編程了0.1000125、0.17000025之類.
double和int的算術運算向double對齊,所以r-int(r)是一個浮點數,顯然當r不是精確二進制小數時,表達式的結果含有小數位,不為double(0),會循環下去.當r較小的時候,表達式的結果僅為一個較小的純小數,當r增大到超過int的極值+2147483648後,(int)r會被截斷,r-int(r)從純小數陡增為極大的浮點數.死循環
你可以嘗試在你的設計中,把r=4.2356改成r=4.125,則不為死循環,可以得到預期結果
或者你改成r-(int)r>0.0001,這樣就只有當r的小數位超過10位的截斷問題.比如r=4.2356時還是無法計算,因為實際存儲位數超過10位,(int)r被截斷後表達式變成很大的浮點數,死循環.
我提供如下演算法.判斷標准比較類似>0.0001這種精確度的折中法,每次*10後判斷個位,連續3次個位為0則退出循環
#include "stdio.h"
main()
{
double r;scanf("%lf",&r);
double r1=(int)r;int m=0,n=0,g;
//g表示個位,r1結合r計算個位
while(1)
{
r*=10;
r1*=10;
g=int(r-r1);
//這樣提取個位比g=int(r)%10可表達的r大,後者r過大會被截斷
r1+=g;
m++;
if(!g)n++;
else n=0;
if(n==3)break;
}
printf("%lf %d",r1/1000,m-3);
}
要注意的是,結果的r1/1000和m-3中只有m有效,表示浮點數實際存儲的小數位,而r1在增大的過程中,可能由於位數過長而被截斷,成為誤差值.例如r=4.2356時,就只有m有效
⑶ c語言中整型和浮點型混合運算的結果是什麼類型
c語言中整型和浮點型混合運算的結果為double型(雙精度浮點類型)。
c語言中如果一個運算符兩邊的運算數類型不同,先要將其轉換為相同的類型,即較低類型轉換為較高類型,然後再參加運算,轉換規則:float(浮點型)轉化為double(雙精度浮點類型)、int(整型)轉為unsigned(無符號整型)轉為long(長整型)轉為(雙精度浮點類型)。
因此,c語言中整型和浮點型混合運算,只能是整型和浮點型同時強制轉換為相同的double型(雙精度浮點類型)。如兩個float型數參加運算,雖然它們類型相同,但仍要先轉成double型再進行運算,結果亦為double型。
(3)整形和浮點型擴展閱讀:
在C語言中,自動類型轉換遵循以下規則:
1、若參與運算量的類型不同,則先轉換成同一類型,然後進行運算。
2、轉換按數據長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉成long型後再進行運算。若兩種類型的位元組數不同,轉換成位元組數高的類型。若兩種類型的位元組數相同,且一種有符號,一種無符號,則轉換成無符號類型。
3、所有的浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表達式,也要先轉換成double型,再作運算。
4、char型和short型參與運算時,必須先轉換成int型。
5、在賦值運算中,賦值號兩邊量的數據類型不同時,賦值號右邊量的類型將轉換為左邊量的類型。如果右邊量的數據類型長度比左邊長時,將丟失一部分數據,這樣會降低精度,丟失的部分按四捨五入向前舍入。
⑷ c語言中整形和浮點型是什麼意思
整型就是整數 如:1,2,3,4
浮點型就是有小數點的 如:0.34,1.8 啥的 浮點型有單精度float 和雙精度double
⑸ 整型除以浮點型是什麼型
浮點型精度高於整形,因此整形數先自動被轉換成浮點型,再進行除法運算,最終結果也為浮點型
⑹ C語言中整型,字元型,浮點型,和雙精度浮點型,詳解
整型,計算機中的一個基本的專業術語,指沒有小數部分的數據。整型可以用十進制,十六進制或八進制符號指定,前面可以加上可選的符號(- 或者 +)。包括整型常量和整型變數,整型變數又包括短整型、基本整型、長整型,它們都分為有符號和無符號兩種版本,是一種智能的計算方式。
字元型量包括字元常量和字元變數。字元串常量由一對雙引號括起的字元序列。字元變數的取值是字元常量,即單個字元。字元變數的類型說明符是char。字元變數類型說明的格式和書寫規則都與整型變數相同。
浮點型利用指數使小數點的位置可以根據需要而上下浮動,從而可以靈活地表達更大范圍的實數。
雙精度浮點型,此數據類型與單精度數據類型(float)相似,但精確度比float高,編譯時所佔的內存空間依不同的編譯器而有所不同,是double float數據類型,C/C++中表示實型變數的一種變數類型。
(6)整形和浮點型擴展閱讀
雙精度浮點型類型數值可轉換到其他類型的整數或浮點數,反之亦然。雙精度浮點型常量的最後一個字元可加上「d」或「D」。其存儲格式與浮點型類似,最高位為符號位,次高11位為指數位,其次52位為尾數。
雙精度型就是雙精度浮點型,同數值型比,它能提供更高的數值精度,採用固定存儲長度的浮點數形式,每個雙精度浮點型數據佔8個位元組。與數值型數據不同,它的小數點位置是由輸入的數據值來決定的,並且只能用於表中的欄位。
⑺ 整型數據和實型數據的區別
整型常量和實型常量
1.整型常量
在 C
語言中,整型常量分為十進制整型常量、八進制整型常量和十六進制整型常量三
種表示形式。
(1)十進制整型常量
這種常量只能出現 0~9
的數字,且可帶正、負號。例如:
0 1 364 28 -34
第 2 章 基本數據類型 •29•
(2)八進制整型常量
這種常量是以數字
0 開頭的八進制數字串。其中數字為 0~7。例如:
0111(十進制 73) 011(十進制 9) 0123(十進制
83)
(3)十六進制整型常量
這種常量是以 0x或 0X開頭的十六進制數字串。其中每個數字可以是 0~9、a~f或 A~
F
中的數字或英文字母。例如:
0x11(十進制 17) 0Xa5(十進制 165) 0x5a(十進制
90)
以上三種進制的常量可用於不同的場合。大多數場合中採用十進制常量,但當編寫系
統程序時,如表示地址等,常用八進制或十六進制常量。
一般情況下,編譯程序會根據常量的數值分辨出常量是
int 還是 long int 類型。但是有
些場合需要明確地指出它是否屬於 long int 類型。此時,可以在整型常量後附加一個字母 l
或 L
強制它為 long int 類型。例如,4126l,78l,5L
等。
2.實型常量
實型常量有兩種表示形式:一種是十進制小數形式,另一種是指數形式。
(1)十進制小數形式
十進制小數形式為包含一個小數點的十進制數字串。
此類實型常量小數點前或後可以沒有數字,但不能同時沒有數字。例如:
3.14159,
.89, 56.0, 78., -3.0,
0.0
(2)指數形式
指數形式的格式由兩部分組成:十進制小數形式或十進制整型常量部分和指數部分。
其中指數部分是在 e 或
E(相當於數學中冪底數 10)後跟整數階碼(即可帶符號的整數指
數)。例如:
1e15 //表示數值 1×10
15
0.35e+1 //表示數值 0.35×10
1
78e-1 //表示數值 78×10
-1
⑻ 浮點型和整型相加,結果是什麼類型
浮點型運算的時候不是一律先變成雙精度型嗎?
⑼ 整型變數和浮點變數的意思和區別
整型是整來數的一部分所組成的集自合;浮點型是實數中的一部分組成的集合,帶小數位。
整型變數就是存放整數的變數,在Dos下,范圍是:-32668~32767;在Windows下,范圍是-2的32次冪到2的32次冪-1
浮點變數:表示以浮點形式表示實數的變數,其中也規定了佔用的空間量,位元組數;以及表示的范圍。
⑽ 整數和浮點數的區別
整數是指正整數、負整數和零,如-6、0、32 等。
浮點數是指帶有有限位小數的有理數,如-10.8、0.00、25.01 等。回
整數答既可以是整數,也可以是浮點數,例如255 是整數,而255.0 則是浮點數。
整數運算,得到的結果是一個整數,並且計算結果中的小數部分將被忽略。例如:用整數運算時,100÷3=33。
浮點運算,得到的結果是一個浮點數,計算結果中的小數部分將保留下來。