2021-07-06

                       ## 标题 实践周7/6所学

一、
1、十进制转换为二进制
除二取余,然后倒序排位,高位补零。也就是说,将十进 制数除以二,得到的商再除以二,以此类推直到商为零或一时为止,然后在旁边标出各步的余数,最后倒着写出来,高位补零就可以了。例如将103转换为二进制数:
103÷2=51余1
51÷2=25 余1
25÷2=12 余1
12÷2=6 余0
6÷2=3 余0
3÷2=1 余1
1÷2=0 余1
故二进制数为1100111
2、十进制转换为十六进制
与十进制转二进制方法相同,十六进制数用0~9和A、B、C、D、E、F进行表示,用短除法进行计算。例如将103转换成十六进制数:
103÷16=6余7
7÷16=0余7
故十六进制数为67
3、十进制转换为八进制
将十进制数除以8取余,直到商为0或1时停止,然后把余数倒序排列。例如将103转换为八进制数:
103÷8=12余7
12÷8=1 余4
1÷8=0 余1
故八进制数147
二、位运算符
逻辑运算符:
1、&:位 ‘与’
2、^:位 ‘异或’
3、|:位 ‘或’
4、~:位 ‘非’,取反
移位运算符:
1、<<:左移
2、>>:右移
逻辑位运算都是以(bit) 为单位。
**“~”**非,取反:0变为1,1变为0,需注意的是,位取反运算并不会改变操作数的值,它只是在内存中进行的。如果想要改变需要重新赋值。

#include<stdio.h>
#include<stdlib.h>

void main()
{
	unsigned char ch = 15;    //0000 1111
	unsigned char ch1 = -ch;  //1111 0000
	unsigned char ch2 = -ch1; //0000 1111

	printf("%d,%d,%d", ch, ch1, ch2);

	system("pause");
}

输出
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值