今天详细的学习了进制转换与操作符内容,下面将我所学知识分享给大家
1.二进制转十进制
|
二进制数 1101 | 1 | 1 | 0 | 1 |
| 权重 | 2的3次方 | 2的2次方 | 2的1次方 | 2的1次方 |
|
乘权重可以换算十进制 然后相加得10进制数13 | 8 | 4 | 0 | 1 |
2.10进制转2进制采用取余法,➗2的余数由下至上写成二进制数
3. 二进制转八进制
|
二进制数 010110101111 | 010 | 110 | 101 | 111 |
| 三个二进制对应一个八进制 | 也是按照权重按位转换 | |||
| 3 | 6 | 5 | 7 |
4.二进制转16进制
与八进制同理。但是4个二进制对应一个16进制数字
5.各进制占位符
int main()
{
int a = 0; // 存储用户输入的十六进制数
printf("请输入你想要打印的16进制数字\n");
scanf("%x", &a); // 以十六进制格式读取输入
// 以不同进制格式输出
printf("你输入的数字是:%d\n", a); // 十进制输出
printf("你输入的数字是:%o\n", a); // 八进制输出
printf("你输入的数字是:%x\n", a); // 十六进制输出
return 0;
}
6.移位运算
int main()
{
int a = 10;
// 左移一位相当于乘以2
int b = a << 1; // a的二进制补码左移一位,左边抛弃,右边补0
printf("%d\n", a);
printf("%d\n", b);
}
7.不借助临时变量交换两个整数:
int main()
{
int a = 5;
int b = 9;
printf("%d %d\n", a, b);
// 使用异或运算交换变量
a = a ^ b; // 第一步:a = a ^ b
b = a ^ b; // 第二步:b = (a ^ b) ^ b = a
a = a ^ b; // 第三步:a = (a ^ b) ^ a = b
printf("%d %d", a, b);
}
8.计算二进制补码中含1的个数
// 方法1:通过模2运算
int main()
{
int a = 0;
int count = 0;
scanf("%d", &a);
while(a)
{
if (a % 2 == 1) // 检查最低位是否为1
{
count++;
}
a /= 2; // 相当于右移一位
}
printf("%d\n", count);
return 0;
}
// 方法2:使用位运算优化
int main()
{
int a = 0;
int count = 0;
scanf("%d", &a);
while (a)
{
a = a & (a - 1); // 每次清除最低位的1
count++;
}
printf("%d的二进制补码中含1的个数为%d", a, count);
}
9.按位与& 按位或| 按位取反
int main()
{
int a = 13;
// 00001011 (13的二进制)
// 将第5位设为1
a = a | (1 << 4); // 00011011 (27)
printf("%d\n", a);
// 将第5位设为0
a = a & (~(1 << 4)); // 00001011 (13)
printf("%d", a);
}
10.逗号表达式
int main()
{
int a = 0;
int b = 2;
// 逗号表达式从左到右计算,结果为最后一个表达式的值
int c = (a, a = b + 10, b = a - 2);
// 计算过程:
// 1. a = 2 + 10 = 12
// 2. b = 12 - 2 = 10
// 3. c = 10
printf("%d", c);
}
11.函数运算操作符
int main()
{
char arr1[10] = "hello";
// []是下标运算符,arr1[1]表示数组第二个元素'e'
printf("%c", arr1[1]);
// ()是函数调用运算符,printf是函数名
// %c是格式控制符,表示输出字符
}
3272

被折叠的 条评论
为什么被折叠?



