存儲整數所需要的位數
A. c語言 整數的位數
int 最多隻能存放2的31方-1
可能溢出了。
換用long long 類型(64位整數類型)試試,不同的編譯器有所不同。
B. 一個位元組是8位,那一個位元組能存儲多少個數字呢
一個位元組8個位,每個位就只有 0 跟 1 兩種情況,8個位能表示 2的8次方 種數,即 256種,范圍0-255(帶負值的話范圍在:-128~127);
0-255 只是一個數,當然 LZ 也可以認為 它是 三個數(百位、十位、個位)。
555 超出了 255 的范圍,8個位已經滿足不了 555 的存儲要求了,一般採用16個位記錄
C. 存儲小於1000整數所需的最小位數
於10000四位數
設數num
十百千位數字別a,b,c,d
a=num%10
b=num/10%10
c=num/100%10
d=num/1000
D. 【大計基】存儲最多為六位的十進制整數所需的最小二進制位數
最大的六位十進制整數是999999,
999999大於2的19次冪,小於2的20次冪
所以至少要用20位二進制數才能存儲最多為六位的十進制整數
E. C語言中整型數據的有效位數是多少
1、從二進制的角度來看整數的有效位數,要從整數的編碼說起,有符號整數編碼包括原碼、反碼和補碼三種常規編碼方式,原碼表示即最高位為符號位,0表示正數,1表示負數,如果以8位二進制位來表示,符號位要佔1位,所以有效位數7位。
要獲取整型類型在當前編譯環境中所佔的位數,可以使用sizeof運算符。
#include<stdio.h>
intmain()
{
printf("sizeofint:%d
",sizeof(int));
return0;
}
2、如果要計算一個整數中的有效位數,可以不斷的整除10求出來。如下代碼:
#include<stdio.h>
inthow_many_int(ints)
{
inti=0;
while(s!=0)
{s/=10;i++;}
returni;
}
intmain()
{
inttest;
do
{
printf("輸入整數:");
scanf("%d",&test);
printf("有%d位
",how_many_int(test));
}while(test!=~0);
return0;
}
說明:輸入數值超出int所表示的范圍,編譯器會對輸入數進行取模操作。輸出-1結束循環,退出程序。
F. c語言的int型數據范圍和內存中存儲是什麼
1、nt型為帶符號整數類型,對於16位編譯器,int佔2位元組8位;對於32位和64位編譯器,int型佔4位元組32位。不同的佔用空間,int型的范圍也不同:2位元組時,int 范圍為-32768~32767;4位元組時,int范圍為-2147483648~2147483647。
無論是哪種存儲方式,均是最高位為符號位,0代表正數,1代表負數。剩餘位存儲實際值。
2、字元是指計算機中使用的字母、數字、字和符號,包括:1、2、3、A、B、C、~!·#¥%……—*()——+等等。在 ASCII 編碼中,一個英文字母字元存儲需要1個位元組。在 GB 2312 編碼或 GBK 編碼中,一個漢字字元存儲需要2個位元組。
3、字元型數據在內存中儲存的是它的ASCII碼值,它是一個位元組,所有數據類型在內存中都是以0和1代碼二進制儲存的,這個原則不會變。
4、在UTF-8編碼中,一個英文字母字元存儲需要1個位元組,一個漢字字元儲存需要3到4個位元組。在UTF-16編碼中,一個英文字母字元或一個漢字字元存儲都需要2個位元組(Unicode擴展區的一些漢字存儲需要4個位元組)。在UTF-32編碼中,世界上任何字元的存儲都需要4個位元組。
5、char是C/C++整型數據之一,其它的如int/long/short等不指定signed/unsigned時都默認是signed,char在標准中是unsigned,編譯器可以實現為帶符號的,也可以實現為不帶符號的,有些編譯器如pSOS的編譯器,還可以通過編譯開關來指定它是有符號數還是無符號數。
G. c語言的int型數據范圍和內存中存儲詳細解釋!
int型為帶符號整數類型,對於16位編譯器,int佔2位元組8位;對於32位和64位編譯器,int型佔4位元組32位。
不同的佔用空間,int型的范圍也不同。
2位元組時,int 范圍為-32768~32767.
4位元組時,int范圍為-2147483648~2147483647
無論是哪種存儲方式,均是最高位為符號位,0代表正數,1代表負數。
剩餘位存儲實際值。
H. C語言中,"整型"跟"短整型"的取值范圍都是 -32768~32767,請問兩者有什麼差別
C語言沒有具體規定各類數據所佔內存的位元組數,只要求long型數據長於int型,short型短於int 型,是由計算機系統自行決定,有的short和 int都是16位,long 是32位,有的short為16位,long和int都是32位,通常是long 為32位,short為16位,而int可以是16位,也可以是32位
這兩個都是用於存儲整數.短整型的二進制位長是16,長整型的是32位.就是說長整型可以表示位數更多的整數.短整型所能表示的整數的值域為-32768~32767,長整型則為-2147483648~2147483647.例如,如果有個數為32780,那麼它只能用長整型表示,而不能用短整型表示.
I. int佔多少位元組
在C/C++語言中,int和long int的所佔的位元組數與編譯器有關。
不過現在常用的編譯器多認為int和long int相同,均為4位元組,short為2位元組,char為1位元組。
如果只輸入int,它是可以包含以上三種形式。
不同的語言不太一樣,例如在Pascal中integer為2位元組,byte為1位元組,而longint為4位元組。
建議您最好參考您的編譯器的具體幫助,以得到更准確的信息。
使用前最好sizeof(int) 看看當前編譯器如何定義的。
依據程序編譯器的不同,int定義的位元組數不同。(數據佔用內存儲器的大小不同)
常用的單片機編譯器,如KEIL下,51類單片機的C語言中,int代表2個位元組(16位);如果是32位RAM處理器的C語言中,則int代表4個位元組(32位)
PIC單片機的PICC中8位系列單片機的C語言里int表示16位。
而不少PC端軟體的編譯器則會根據操作系統或處理器(如64位XP)把int定義為8位元組(64位)
所以在多平台上編程的人員需要在使用時注意。
如需定義16位數,可使用short(短、短整數類型)定義。
(9)存儲整數所需要的位數擴展閱讀:
在一般的電腦中,int佔用4位元組,32比特,數據范圍為-2147483648~2147483647[-2^31~2^31-1]。
在之前的微型機中,int佔用2位元組,16比特,數據范圍為-32768~32767[-2^15~2^15-1]。
使用printf輸出int佔用位元組數量:
除了int類型之外,還有short、long、long long類型可以表示整數。
unsigned int 表示無符號整數,數據范圍為[0~2^32-1]。
參考鏈接:INT(數據類型)_網路