① c語言中實型變數有分正負嗎
實型變數存儲的時候計算機是不分正負的,因為他用asc 碼存;
但是你可以用負數,他會轉換成他的補碼進行存儲的
② 用c語言怎麼判斷一個數的正負及怎麼取整數
floor
【功能】向下取整函數。
【原型】double floor(double x)
【位置】math.h
【說明】返回小於或等於x的最大整數
③ 輸入一個數,判斷正負,C語言寫程序,初學者,不太懂怎麼寫
主函數中這么寫:
int a;
printf("input a number:");
scanf("%d",&a);
if(a>0)printf("%d is 正數.",a);
else if(a==0)printf("%d is 0.",a);
else if(a<0)printf("%d is 負數.",a);
④ c語言常量前面可以有兩個負號嗎
不可以。兩個負號的話要用括弧: -(-3). 因為-- 會被看作自減運算
⑤ C語言中為什麼負數是字元串常量
答案沒錯:
「-518」是字元串常量;
-518才是負整數。
學C語言,有些基本的概念要記住。如:
"1"是個字元串(在半形的雙引號之間);
『1』是個字元(在半形的單引號之間);
1是個整數。
⑥ C語言中,-0x5B這種表達方式對嗎也就是說16進制的整型常量有負數嗎請解釋
沒有任何問題。
0x5b只是16進制方式表示的整數,我們都知道整數是可以是正數或負數的,所以這樣表示沒有問題。
不論是二進制、八進制、十進制、十六進制甚至是三十二進制還是多少多少進制,都只是一種數值的表示方法而已,它們歸根結底表示的都是整數,理解了這一點就好了。
----------------------
對補充信息的回答:
我說過,這些只是不同進制對整數的表示方法。八進制、十六進制同樣可以表示負數。比如你舉的例子,-1這個值,十六進製表示為0xFFFFFFFF。這裡面第一位數(就是0x後面的第一個F),它的二進制值是1111,這4個1的第一位1就是符號位,為0表示整個數為正值,為1表示整個數為復制。
也就是說,0x8-0xf開頭的十六進制數就是負數。
八進制類似。
再說一句,計算機程序中,我們平時的正負號(+和-)是為了描述十進制數使用的,其他進制有自己的正負值表示方法,並不使用正負號。
⑦ 在C語言中,int型常量包不包括負數
包括,無符號整型不包括,整型是包括的。
int k=5; while(--k)printf("%d",k-=3;); 執行過程是:
k=5,然後執行while語句,因為--在前,先執行減1操作再執行判斷,k=4,執行循環,k-=3,也就是k=k-3,將k減3的值輸出,也就是1,然後繼續while語句,執行減1操作後k=0,循環結束。
⑧ C語言區分int數據正負的問題
類型是對一串二進制位的解釋,這16bit有兩種解釋,有符號整數,有無符號整數。
按有符號數來解釋,最高位是符號位,1表示負數,其值為-20840。
按無符號數來解釋,值為44696。
⑨ 在c語言中,整型常量的八進制常量能否負數
沒有任何問題。
0x5b只是16進制方式表示的整數,我們都知道整數是可以是正數或負數的,所以這樣表示沒有問題。
不論是二進制、八進制、十進制、十六進制甚至是三十二進制還是多少多少進制,都只是一種數值的表示方法而已,它們歸根結底表示的都是整數,理解了這一點就好了。
----------------------
對補禒窢操喝鬲估叉台常郡充信息的回答:
我說過,這些只是不同進制對整數的表示方法。八進制、十六進制同樣可以表示負數。比如你舉的例子,-1這個值,十六進製表示為0xffffffff。這裡面第一位數(就是0x後面的第一個f),它的二進制值是1111,這4個1的第一位1就是符號位,為0表示整個數為正值,為1表示整個數為復制。
也就是說,0x8-0xf開頭的十六進制數就是負數。
八進制類似。
再說一句,計算機程序中,我們平時的正負號(+和-)是為了描述十進制數使用的,其他進制有自己的正負值表示方法,並不使用正負號。
⑩ C語言如何表示正負值問題
c語言有兩種數據類型,一種是整型,一種是浮點型 ,整型類型一般用的原碼表示,浮點類型一般用的IEEE754標准進行編碼。
整型數中原碼表示正負數,取最高位為符號位,以8位二進制數來表示1和-1。1的二進制為
0 000 0001 //最高位為符號位,0表示正數,1表示負數
1 000 0001 //這個表示-1
IEEE754浮點數編碼,使用的格式類似於 (-1)^s * M* 2^E,其中s是符號位,M是有效位數,E指的是指數,s符號位佔1位,如果是0,則(-1)的0次方為1,表示是一個正數,如果s位是-1,則表示是一個負數。