C语言——操作符详解2

0.过渡

  • 在操作符1中我们最后讲了位操作符的概念
  • 这里我想举几个例子加深理解

0.1 不创建临时变量,交换两数

  • 这是一道很变态的面试题
  • 首先我们可以看看下面两个等式:
  1. a ^ a =0
  2. a ^ 0 = a
  • 接着我们来理解一下这道变态面试题的答案
#include <stdio.h>
int main()
{
   
	int a = 10;
	int b = 20;
	a = a^b;
	b = a^b;//根据上面的代码,这里的a^b=a^b^b=a^0=a,这里相当于把a给b
	a = a^b;//根据上面的代码,这里的a^b=a^a^b=0^b=b,这里相当于把b给a
	printf("a = %d b = %d\n", a, b);
	return 0;
}
  • 运行结果如下:

在这里插入图片描述

0.2 求整数转成二进制后1的总数

  • 首先我们看一下当一个二进制数和1按位与后的结果

在这里插入图片描述

  • 我们发现当一个二进制的最后一位是 0 时,和1按位与后的结果为0
  • 当最后一位为1时,按位与1后的结果时1
  • 这样就相当于把二进制的最后一位给取出来了,那么我只要加个循环,把每一位都取出来再相加即可(这里我为了方便只写了八个二进制数,×86环境为32位,×64环境为64位)
  • 所以代码如下:
#include <stdio.h>

int main()
{
   
	int num = -1;
	int i = 0;
	int count = 0;//计数
	
	for(i=0; i<32; i++)
	{
   
		if( num & (1 << i) )
		count++;
	}
	
	printf("⼆进制中1的个数 = %d\n",count);
	
	return 0;
}
  • 但是这样有一个缺点,就是不管二进制是多少都要循环32遍,如果二进制只是1,那31遍循环都白循环了
  • 所以我们想想是否还有更加高效的代码呢
  • 比如我们可以试试 num&(num-1)

在这里插入图片描述

  • 我们会发现最后的1消失了
  • 同理,如果我们把结果再重复一次运算

在这里插入图片描述

  • 我们会发现倒数第二个1也消失了,如果我们再重复一次会不会倒数第四位的1也消失呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

看落日的YT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值