① c語言中的二進制、十進制、十六進制各是什麼意思
計算機中常用的數的進制主要有:二進制、八進制、十六進制,學習計算機要對其有所了解。
2進制,用兩個阿拉伯數字:0、1;
8進制,用八個阿拉伯數字:0、1、2、3、4、5、6、7;
10進制,用十個阿拉伯數字:0到9;
16進制就是逢16進1,但我們只有0~9這十個數字,所以我們用A,B,C,D,E,F這五個字母來分別表示10,11,12,13,14,15。字母不區分大小寫。
以下簡介各種進制之間的轉換方法:
一、二進制轉換十進制
例:二進制 「1101100」
1101100 ←二進制數
6543210 ←排位方法
例如二進制換算十進制的演算法:
1*26 + 1*25 + 0*24 + 1*23 + 1* 22 + 0*21 + 0*20
↑ ↑
說明:2代表進制,後面的數是次方(從右往左數,以0開始)
=64+32+0+8+4+0+0
=108
二、二進制換算八進制
例:二進制的「10110111011」
換八進制時,從右到左,三位一組,不夠補0,即成了:
010 110 111 011
然後每組中的3個數分別對應4、2、1的狀態,然後將為狀態為1的相加,如:
010 = 2
110 = 4+2 = 6
111 = 4+2+1 = 7
011 = 2+1 = 3
結果為:2673
三、二進制轉換十六進制
十六進制換二進制的方法也類似,只要每組4位,分別對應8、4、2、1就行了,如分解為:
0101 1011 1011
運算為:
0101 = 4+1 = 5
1011 = 8+2+1 = 11(由於10為A,所以11即B)
1011 = 8+2+1 = 11(由於10為A,所以11即B)
結果為:5BB
四、二進制數轉換為十進制數
二進制數第0位的權值是2的0次方,第1位的權值是2的1次方……
所以,設有一個二進制數:0110 0100,轉換為10進制為:
計算: 0 * 20 + 0 * 21 + 1 * 22 + 0 * 23 + 0 * 24 + 1 * 25 + 1 * 26 + 0 * 27 = 100
五、八進制數轉換為十進制數
八進制就是逢8進1。
八進制數採用 0~7這八數來表達一個數。
八進制數第0位的權值為8的0次方,第1位權值為8的1次方,第2位權值為8的2次方……
所以,設有一個八進制數:1507,轉換為十進制為:
計算: 7 * 80 + 0 * 81 + 5 * 82 + 1 * 83 = 839
結果是,八進制數 1507 轉換成十進制數為 839
六、十六進制轉換十進制
例:2AF5換算成10進制
直接計算就是: 5 * 160 + F * 161 + A * 162 + 2 * 163 = 10997
(別忘了,在上面的計算中,A表示10,而F表示15)、
現在可以看出,所有進制換算成10進制,關鍵在於各自的權值不同。
假設有人問你,十進數 1234 為什麼是 一千二百三十四?你盡可以給他這么一個算式: 1234 = 1 * 103 + 2 * 102 + 3 * 101 + 4 * 100
十進制與二進制轉換之相互演算法
十進制轉二進制:
用2輾轉相除至結果為1
將余數和最後的1從下向上倒序寫 就是結果
例如302
302/2 = 151 餘0
151/2 = 75 餘1
75/2 = 37 餘1
37/2 = 18 餘1
18/2 = 9 餘0
9/2 = 4 餘1
4/2 = 2 餘0
2/2 = 1 餘0
故二進制為100101110
二進制轉十進制
從最後一位開始算,依次列為第0、1、2...位
第n位的數(0或1)乘以2的n次方
得到的結果相加就是答案
例如:01101011.轉十進制:
第0位:1乘2的0次方=1
1乘2的1次方=2
0乘2的2次方=0
1乘2的3次方=8
0乘2的4次方=0
1乘2的5次方=32
1乘2的6次方=64
0乘2的7次方=0
然後:1+2+0
+8+0+32+64+0=107.
二進制01101011=十進制107.
一、二進制數轉換成十進制數
由二進制數轉換成十進制數的基本做法是,把二進制數首先寫成加權系數展開式,然後按十進制加法規則求和。這種做法稱為"按權相加"法。
二、十進制數轉換為二進制數
十進制數轉換為二進制數時,由於整數和小數的轉換方法不同,所以先將十進制數的整數部分和小數部分分別轉換後,再加以合並。
1. 十進制整數轉換為二進制整數
十進制整數轉換為二進制整數採用"除2取余,逆序排列"法。具體做法是:用2去除十進制整數,可以得到一個商和余數;再用2去除商,又會得到一個商和余數,如此進行,直到商為零時為止,然後把先得到的余數作為二進制數的低位有效位,後得到的余數作為二進制數的高位有效位,依次排列起來。
2.十進制小數轉換為二進制小數
十進制小數轉換成二進制小數採用"乘2取整,順序排列"法。具體做法是:用2乘十進制小數,可以得到積,將積的整數部分取出,再用2乘餘下的小數部分,又得到一個積,再將積的整數部分取出,如此進行,直到積中的小數部分為零,或者達到所要求的精度為止。
然後把取出的整數部分按順序排列起來,先取的整數作為二進制小數的高位有效位,後取的整數作為低位有效位。
1.二進制與十進制的轉換
(1)二進制轉十進制<BR>方法:"按權展開求和"
例:
(1011.01)2 =(1×23+0×22+1×21+1×20+0×2-1+1×2-2)10
=(8+0+2+1+0+0.25)10
=(11.25)10
(2)十進制轉二進制
· 十進制整數轉二進制數:"除以2取余,逆序輸出"
例: (89)10=(1011001)2
2 89
2 44 …… 1
2 22 …… 0
2 11 …… 0
2 5 …… 1
2 2 …… 1
2 1 …… 0
0 …… 1
· 十進制小數轉二進制數:"乘以2取整,順序輸出"
例:
(0.625)10= (0.101)2
0.625
X 2
1.25
X 2
0.5
X 2
1.0
2.八進制與二進制的轉換
例:將八進制的37.416轉換成二進制數:
37 . 4 1 6
011 111 .100 001 110
即:(37.416)8 =(11111.10000111)2
例:將二進制的10110.0011 轉換成八進制:
0 1 0 1 1 0 . 0 0 1 1 0 0
2 6 . 1 4
即:(10110.011)2 =(26.14)8
3.十六進制與二進制的轉換<BR>例:將十六進制數5DF.9 轉換成二進制:
5 D F . 9
0101 1101 1111.1001
即:(5DF.9)16 =(10111011111.1001)2
例:將二進制數1100001.111 轉換成十六進制:
0110 0001 . 1110
6 1 . E
即:(1100001.111)2 =(61.E)16
② c語言中 k*=2 是什麼意思
k是一個指針,這句話的意思是k指向的地址中存放的變數值等於2,k=k*2;//將k乘以2並將結果賦值給k這個變數。
舉例:如果a=2,k=&a,則執行*k+=2後,a=4,相當於執行了a=a+2。
k*=2等價於k=k*2;
k-=2k=k-2
k+=2k=k+2
k/=2k=k/2
k%=2k=k%2
(2)在c語言中2代表什麼意思擴展閱讀
C語言「->」運算符
C語言代碼定義了結構體S,成員a代表0偏移,而成員b則代表2位元組偏移(這里假設int變數佔用2位元組內存,也不考慮內存對齊)。
代碼定義了結構體X,它也包含成員a,它的名字與結構體S中的成員a重復了,但是沒有問題,因為它們都代表0偏移。因為結構體Y中的成員a與結構體S中的成員a重名,並且代表的位元組偏移量也不相等。
③ C語言中data[2]是什麼意思
data[2]表示取數組data中的第三個元素(C語言中,數組下標從0開始)。
下面結合具體實例來說明data[2]的含義:
intdata[5]={2,5,4,7,1};//定義一個int型數組,數組名為data,包含5個元素,並對每個元素都進行初始化
inta;
a=data[2];//取出data數組中下標為2的元素(即第三個元素)的值賦值給變數a
printf("%d",a);//輸出變數a的值,輸出為4
④ c語言中雙引號的2(「2」)是什麼意思,,下午考試,急!!!
s雙引號中的2代表字元'2',s由於是用了雙引號,代表一個字元串,其中s[0]=='2',相當於50(ASCII碼),s[1]=='\0',相當於0。
⑤ 在C語言中b=a<<2;是什麼意思
在C語言中,b=a<<2代表將a移位後的值賦值給b
例如:100的二進製表示為1100100,100左移2位後,後面加2個零1100100<<2=110010000=400,可以看出,a<<b的值實際上就是a乘以2的b次方,因為在二進制數後面添加一個0就相當該數乘以2,2個零即2的2次方等於4。
通常認為a<<1比a*2更快,因為前者是更底層一些的操作。因此程序中乘以2的操作盡量用左移一位來代替。
(5)在c語言中2代表什麼意思擴展閱讀
C 語言支持的賦值運算符
=: 簡單的賦值運算符,把右邊操作數的值賦給左邊操作數。如C = A + B 將把 A + B 的值賦給 C 。
+=:加且賦值運算符,把右邊操作數加上左邊操作數的結果賦值給左邊操作數。如C += A 相當於 C = C + A。
-=:減且賦值運算符,把左邊操作數減去右邊操作數的結果賦值給左邊操作數。如C -= A 相當於 C = C - A。
*=:乘且賦值運算符,把右邊操作數乘以左邊操作數的結果賦值給左邊操作數。如C *= A 相當於 C = C * A。
/=:除且賦值運算符,把左邊操作數除以右邊操作數的結果賦值給左邊操作數。如C /= A 相當於 C = C / A。
%=:求模且賦值運算符,求兩個操作數的模賦值給左邊操作數。如C %= A 相當於 C = C % A。
<<=:左移且賦值運算符。如C <<= 2 等同於 C = C << 2。
>>=:右移且賦值運算符。如C >>= 2 等同於 C = C >> 2。
&=:按位與且賦值運算符。如C &= 2 等同於 C = C & 2。
^=:按位異或且賦值運算符。如C ^= 2 等同於 C = C ^ 2。
|=:按位或且賦值運算符。如 C |= 2 等同於 C = C | 2。
⑥ C語言二叉樹中「度」為0,1,2各是什麼意思啊
只有一個根,沒有孩子的二叉樹度為0,所有節點只有一個孩子的二叉樹的度為1,節點中有兩個孩子的二叉樹的度為2。
樹所包含的節點中,擁有最大的分支的數目為該樹的度。二叉樹的度小於等於2,因為二叉樹的定義要求二叉樹中任意結點的度數(結點的分支數)小於等於2 ,並且兩個子樹有左右之分,順序不可顛倒。
(6)在c語言中2代表什麼意思擴展閱讀:
二叉樹葉子結點計算方法:
例:一棵樹度為4,其中度為1,2,3,4的結點個數分別為4,2,1,1,則這棵樹的葉子節點個數為多少?
解:因為任一棵樹中,結點總數=度數*該度數對應的結點數+1,所以:
n0+4+2+1+1 = (0*n0 + 1*4 + 2*2 + 3*1 + 4*1)+1
則:n0=8
其中:n0表示葉子結點。
⑦ C語言中數字2.0和2有什麼區別
C語言中數字2.0是表示一個double型的常量,2則是表示一個int型的常量。它們適用的運算規則是不一樣的。
在C語言中,
2.0/4的值是0.5
而2/4的值則是0
⑧ c語言中1/2是什麼意思
c語言中1/2表示用整數1除以整數2,因為兩者都是整數,其運算結果為0。
C語言是一門面向過程的、抽象化的通用程序設計語言,廣泛應用於底層開發。C語言能以簡易的方式編譯、處理低級存儲器。C語言是僅產生少量的機器語言以及不需要任何運行環境支持便能運行的高效率程序設計語言。盡管C語言提供了許多低級處理的功能,但仍然保持著跨平台的特性,以一個標准規格寫出的C語言程序可在包括類似嵌入式處理器以及超級計算機等作業平台的許多計算機平台上進行編譯。
(8)在c語言中2代表什麼意思擴展閱讀:
C語言是普適性最強的一種計算機程序編輯語言,它不僅可以發揮出高級編程語言的功用,還具有匯編語言的優點,因此相對於其它編程語言,它具有自己獨特的特點。具體體現在以下三個方面:
其一,廣泛性。C 語言的運算范圍的大小直接決定了其優劣性。C 語言中包含了34種運算符,因此運算范圍要超出許多其它語言,此外其運算結果的表達形式也十分豐富。此外,C 語言包含了字元型、指針型等多種數據結構形式,因此,更為龐大的數據結構運算它也可以應付。
其二,簡潔性。9 類控制語句和32個KEYWORDS是C語言所具有的基礎特性,使得其在計算機應用程序編寫中具有廣泛的適用性,不僅可以適用廣大編程人員的操作,提高其工作效率,同 時還能夠支持高級編程,避免了語言切換的繁瑣。
其三,結構完善。C語言是一種結構化語言,它可以通過組建模塊單位的形式實現模塊化的應用程序,在系統描述方面具有顯著優勢,同時這一特性也使得它能夠適應多種不同的編程要求,且執行效率高。
⑨ '2'在c語言中表示什麼
你說的應該是printf函數吧:
通俗的說%m.n中m標示寬度,n標示小數點後顯示幾位。你的就是顯示5個寬度,其中顯示2位小數。
如果你想了解詳細和根本的,看下面的(來自網路文庫):
int printf(const char *format,[argument]);
format 參數輸出的格式,定義格式為:%[flags][width][.perc][F|N|h|l]type
2.flags 規定輸出格式,取值和含義如下:
無 右對齊,左邊填充0和空格
- 左對齊,右邊填充空格
+ 在數字前增加符號 + 或 -
0 將輸出的前面補上0,直到占滿指定列寬為止(不可以搭配使用-)
空格 輸出值為正時冠以空格,為負時冠以負號
# 當type=c,s,d,i,u時沒有影響
type=o,x,X時,分別在數值前增加'0',"0x","0X"
type=e,E,f時,總是使用小數點
type=g,G時,除了數值為0外總是顯示小數點
3.width 用於控制顯示數值的寬度,取值和含義如下
n(n=1,2,3...) 寬度至少為n位,不夠以空格填充
0n(n=1,2,3...) 寬度至少為n位,不夠左邊以0填充
* 格式列表中,下一個參數還是width
4.prec 用於控制小數點後面的位數,取值和含義如下:
無 按預設精度顯示
0 當type=d,i,o,u,x時,沒有影響
type=e,E,f時,不顯示小數點
n(n=1,2,3...) 當type=e,E,f時表示的最大小數位數
type=其他,表示顯示的最大寬度
.* 格式列表中,下一個參數還是width
希望有用。
⑩ C語言中 !2 是什麼意思 非2
if(a!=2)
的意思就是當a不等於2時,!就是非,否的意思
!2就是非2的意思