C++知识点总结(31):位运算、进制转换
位运算、进制转换
一、前言
位运算和进制转换都是非常热门的题目。在 CCF CSP-J/S
,GESP
初赛的时候有选择题,其中大规模的就是位运算和进制转换。根据近
10
10
10 年的调查情况,有接近
10
%
10\%
10% 的题目考察位运算,有接近
30
%
30\%
30% 的题目考察进制转换。
二、位运算
1. 按位与 &
例题: ( 1101101 ) 2 & ( 101001 ) 2 = ( 0101001 ) 2 (1101101)_2 \& (101001)_2=(0101001)_2 (1101101)2&(101001)2=(0101001)2
数字1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
---|---|---|---|---|---|---|---|
数字2 | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
结果 | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
技巧:全 1 1 1 则 1 1 1,一 0 0 0 则 0 0 0
2. 按位或 |
例题: ( 1101101 ) 2 ∣ ( 101001 ) 2 = ( 1101101 ) 2 (1101101)_2 | (101001)_2=(1101101)_2 (1101101)2∣(101001)2=(1101101)2
数字1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
---|---|---|---|---|---|---|---|
数字2 | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
结果 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
技巧:全 0 0 0 则 0 0 0,一 1 1 1 则 1 1 1
3. 按位异或 ^
例题: ( 1101101 ) 2 (1101101)_2 (1101101)2 ^ ( 101001 ) 2 = ( 1000100 ) 2 (101001)_2=(1000100)_2 (101001)2=(1000100)2
数字1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
---|---|---|---|---|---|---|---|
数字2 | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
结果 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
技巧:一 1 1 1 则 1 1 1,否则为 0 0 0
4. 按位取反 ~
例题: ( 1101101 ) 2 = ( 0010010 ) 2 ~ (1101101)_2=(0010010)_2 (1101101)2=(0010010)2
数字 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
---|---|---|---|---|---|---|---|
结果 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
技巧: 1 1 1 则 0 0 0,否则为 1 1 1
5. 按位左移 <<
例题:
(
1101101
)
2
<
<
(
2
)
(1101101)_2 << (2)
(1101101)2<<(2)
10
10
10
=
(
110110100
)
2
=(110110100)_2
=(110110100)2
技巧:左移
n
n
n 位就添
n
n
n 个
0
0
0
6. 按位右移 >>
例题:
(
1101101
)
2
>
>
(
2
)
(1101101)_2 >> (2)
(1101101)2>>(2)
10
10
10 $
技巧:右移
n
n
n 位就取前
n
n
n 位
三、进制转换
1. 二进制数计算
例
1
1
1:
(
101
)
2
+
(
11
)
2
=
(
1000
)
2
(101)_2+(11)_2=(1000)_2
(101)2+(11)2=(1000)2
【解析】
1
+
1
=
2
1+1=2
1+1=2,满
2
2
2 进
1
1
1,进
1
1
1 写
0
0
0
0
+
1
+
1
=
2
0+1+1=2
0+1+1=2,满
2
2
2 进
1
1
1,进
1
1
1 写
0
0
0
1
+
1
=
2
1+1=2
1+1=2,满
2
2
2 进
1
1
1,进
1
1
1 写
0
0
0
例
2
2
2:
(
101
)
2
−
(
11
)
2
=
(
10
)
2
(101)_2-(11)_2=(10)_2
(101)2−(11)2=(10)2
【解析】
1
−
1
=
0
1-1=0
1−1=0,写
0
0
0
0
−
1
0-1
0−1 不够减,向前借
1
1
1 当
2
2
2,
2
−
1
=
1
2-1=1
2−1=1,写
1
1
1
2011
−
2011-
2011−CSP-J
:在二进制下,
1010110
+
x
=
1100011
1010110+x=1100011
1010110+x=1100011,求
x
x
x。
【解析】
1
−
0
=
1
1-0=1
1−0=1,写
1
1
1
1
−
1
=
0
1-1=0
1−1=0,写
0
0
0
0
−
1
0-1
0−1 不够减,向前借
1
1
1 当
2
2
2,
2
−
1
=
1
2-1=1
2−1=1,写
1
1
1
(
−
1
)
−
0
(-1)-0
(−1)−0 不够减,向前借
1
1
1 当
2
2
2,
2
−
1
=
1
2-1=1
2−1=1,写
1
1
1
再往前,全部都是
0
0
0。
2. 十进制转 x 进制
2.1 十进制转二进制
例
1
1
1:
(
12
)
(12)
(12)
10
10
10
=
(
?
?
)
2
=(??)_2
=(??)2
【方法】 不断地用数字除以
2
2
2,将余数逆序输出
【解析】
操作 | 结果 | 余数 |
---|---|---|
12 ÷ 2 12\div2 12÷2 | 6 6 6 | 0 0 0 |
6 ÷ 2 6\div2 6÷2 | 3 3 3 | 0 0 0 |
3 ÷ 2 3\div2 3÷2 | 1 1 1 | 1 1 1 |
1 ÷ 2 1\div2 1÷2 | 0 0 0 | 1 1 1 |
所以 ( 12 ) (12) (12) 10 10 10 = ( 1100 ) 2 =(1100)_2 =(1100)2
例
2
2
2:
(
0.125
)
(0.125)
(0.125)
10
10
10
=
(
?
?
)
2
=(??)_2
=(??)2
【方法】 不断用得到的数字乘
2
2
2,结果超
0
0
0,那么整数部分变成
0
0
0,顺序输出
【解析】
操作 | 结果 | 取整 |
---|---|---|
0.125 × 2 0.125\times2 0.125×2 | 0.25 0.25 0.25 | 0 0 0 |
0.25 × 2 0.25\times2 0.25×2 | 0.5 0.5 0.5 | 0 0 0 |
0.25 × 2 0.25\times2 0.25×2 | 1 1 1 | 1 1 1 |
所以 ( 0.125 ) (0.125) (0.125) 10 10 10 = ( 0.001 ) 2 =(0.001)_2 =(0.001)2
2.2 十进制转八进制
例
1
1
1:
(
15
)
(15)
(15)
10
10
10
=
(
?
?
)
8
=(??)_8
=(??)8
【方法】 不断地用数字乘
8
8
8,将余数逆序输出
【解析】
操作 | 结果 | 余数 |
---|---|---|
15 ÷ 8 15\div8 15÷8 | 1 1 1 | 7 7 7 |
1 ÷ 8 1\div8 1÷8 | 1 1 1 | 1 1 1 |
所以 ( 15 ) (15) (15) 10 10 10 = ( 17 ) 8 =(17)_8 =(17)8
例
2
2
2:
(
0.625
)
(0.625)
(0.625)
10
10
10
=
(
?
?
)
8
=(??)_8
=(??)8
【方法】 不断地用数字除以
8
8
8,结果超
0
0
0,那么整数部分变成
0
0
0,顺序输出
【解析】
操作 | 结果 | 取整 |
---|---|---|
0.625 × 8 0.625\times8 0.625×8 | 5.0 5.0 5.0 | 5 5 5 |
所以 ( 0.625 ) (0.625) (0.625) 10 10 10 = ( ? ? ) 8 =(??)_8 =(??)8
2.3 十进制转十六进制
例题:保留两位小数:
(
257.12
)
(257.12)
(257.12)
10
10
10
=
(
?
?
)
=(??)
=(??)
16
16
16
【方法】 分开算
【解析】
操作 | 结果 | 余数/取整 |
---|---|---|
257 ÷ 16 257\div16 257÷16 | 16 16 16 | 1 1 1 |
16 ÷ 16 16\div16 16÷16 | 1 1 1 | 0 0 0 |
1 ÷ 16 1\div16 1÷16 | 0 0 0 | 1 1 1 |
== | == | == |
0.12 × 16 0.12\times16 0.12×16 | 1.92 1.92 1.92 | 1 1 1 |
0.92 × 16 0.92\times16 0.92×16 | 14.72 14.72 14.72 | 14 14 14 即 D D D |
3. x 进制转十进制
【方法】 位权展开求和
【解释】 按照每个数位所处的位置所对应的数值乘当前选中的一个数字,求这些结果的和
3.1 二进制转十进制
例题:
(
1011.01
)
2
(1011.01)_2
(1011.01)2
方法:
(
1011.01
)
2
=
(
1
×
2
3
+
0
×
2
2
+
1
×
2
1
+
1
×
2
0
+
0
×
2
(1011.01)_2=(1\times2^3+0\times2^2+1\times2^1+1\times2^0+0\times2
(1011.01)2=(1×23+0×22+1×21+1×20+0×2
−
1
-1
−1
+
1
×
2
+1\times2
+1×2
−
2
-2
−2
)
)
)
10
10
10
=
(
8
+
0
+
2
+
1
+
0
+
0.25
)
=(8+0+2+1+0+0.25)
=(8+0+2+1+0+0.25)
10
10
10
=
(
11.25
)
=(11.25)
=(11.25)
10
10
10
3.2 八进制转十进制
例题:
(
17.2
)
8
(17.2)_8
(17.2)8
方法:
(
17.2
)
8
=
(
1
×
8
1
+
7
×
8
0
+
2
×
8
(17.2)_8=(1\times8^1+7\times8^0+2\times8
(17.2)8=(1×81+7×80+2×8
−
1
-1
−1
)
)
)
10
10
10
=
(
8
+
7
+
2
8
)
=(8+7+\frac{2}{8})
=(8+7+82)
10
10
10
=
(
15.25
)
=(15.25)
=(15.25)
10
10
10
3.2 十六进制转十进制
例题:
(
10
F
.
8
)
(10F.8)
(10F.8)
16
16
16
方法:
(
10
F
.
8
)
(10F.8)
(10F.8)
16
16
16
=
(
1
×
1
6
2
+
0
×
1
6
1
+
15
×
1
6
0
+
8
×
16
=(1\times16^2+0\times16^1+15\times16^0+8\times16
=(1×162+0×161+15×160+8×16
−
1
-1
−1
)
)
)
10
10
10
=
(
256
+
0
+
15
+
8
16
)
=(256+0+15+\frac{8}{16})
=(256+0+15+168)
10
10
10
=
(
271.5
)
=(271.5)
=(271.5)
10
10
10
4. x 进制转 y 进制
4.1 八进制和二进制
熟记下表:
八进制 | 二进制 |
---|---|
0 | 000 |
1 | 001 |
2 | 010 |
3 | 011 |
4 | 100 |
5 | 101 |
6 | 110 |
7 | 111 |
例
1
1
1:
(
245.206
)
8
=
(
?
?
)
2
(245.206)_8=(??)_2
(245.206)8=(??)2
方法:
八进制 | 二进制 |
---|---|
2 | 010 |
4 | 100 |
5 | 101 |
. | . |
2 | 010 |
0 | 000 |
6 | 110 |
所以, ( 245.206 ) 8 = ( 010100101.010000110 ) 2 (245.206)_8=(010100101.010000110)_2 (245.206)8=(010100101.010000110)2
例
2
2
2:
(
10100101.01000011
)
2
=
(
?
?
)
8
(10100101.01000011)_2=(??)_8
(10100101.01000011)2=(??)8
方法:
第一步,前添零,后添零(整数部分、小数部分的长度添到
3
3
3 的倍数)。
(
10100101.01000011
)
2
=
(
010100101.010000110
)
2
(10100101.01000011)_2=(010100101.010000110)_2
(10100101.01000011)2=(010100101.010000110)2
第二步,对表。
二进制 | 八进制 |
---|---|
010 | 2 |
100 | 4 |
101 | 5 |
. | . |
010 | 2 |
000 | 0 |
110 | 6 |
4.2 十六进制和二进制
熟记下表:
十六进制 | 二进制 | 十六进制 | 二进制 |
---|---|---|---|
0 | 0000 | 8 | 1000 |
1 | 0001 | 9 | 1001 |
2 | 0010 | 10 | 1010 |
3 | 0011 | 11 | 1011 |
4 | 0100 | 12 | 1100 |
5 | 0101 | 13 | 1101 |
6 | 0110 | 14 | 1110 |
7 | 0111 | 15 | 1111 |
例
1
1
1:
(
72.2
)
(72.2)
(72.2)
16
16
16
=
(
?
?
)
2
=(??)_2
=(??)2
方法:
十六进制 | 二进制 |
---|---|
7 | 0111 |
2 | 0100 |
. | . |
2 | 0100 |
所以, ( 72.2 ) (72.2) (72.2) 16 16 16 = ( 1110100.0100 ) 2 =(1110100.0100)_2 =(1110100.0100)2
例
2
2
2:
(
1110010.001
)
2
=
(
?
?
)
(1110010.001)_2=(??)
(1110010.001)2=(??)
16
16
16
方法:
第一步,前添零,后添零(整数部分、小数部分的长度添到
4
4
4 的倍数)。
(
1110010.001
)
2
=
(
01110010.0010
)
2
(1110010.001)_2=(01110010.0010)_2
(1110010.001)2=(01110010.0010)2
第二步,对表。
二进制 | 十六进制 |
---|---|
0111 | 7 |
0010 | 2 |
. | . |
0010 | 2 |
所以, ( 1110100.0100 ) 2 (1110100.0100)_2 (1110100.0100)2 = ( 72.2 ) =(72.2) =(72.2) 16 16 16
原文地址:https://blog.csdn.net/joe_g12345/article/details/138254385
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!