【C语言/C++】操作符和算数转换练习

1、引言

今天这篇博客是关于操作符应用题目训练的总结

2、练习

1、统计二进制中1的个数

方法一、

思路:
如果一个数的二进制中有 1 存在,那么这个数就不可能是 0,我们将这个数字先对2取余(%2),如果二进制最后一位等于 1,计数器就+1,然后再将这个数字对2求商( /2 ),去掉二进制中的最后一位的 1,如此往复,就能算出二进制中 1 的个数。
在这里插入图片描述
上面这个方法的缺点在于只能计算正整数的补码中 1 的个数,不能计算负数
倘若实在需要计算负数,需将形参类型改为 unsigned int 类型。
在这里插入图片描述
方法二、

思路:
若这个数 &1(按位与 1),得到的结果是 1,说明最后一个二进制位是1,然后我们就让计数器 +1,计数器统计完之后让补码 >(右移)一位,舍弃最后一个二进制位,之后重复 32次(因为二进制补码在内存中有32位)上面的操作,直至计数器计算完补码中所有 1 的个数。
在这里插入图片描述
方法三(较为精妙的算法)

思路:
利用 m = m & ( m - 1 ) 这个表达式 会将 m的二进制序列中最右边的1去掉 这个特性来计算二进制位中有多少个 1,循环这个表达式多少次,就代表二进制位中有多少个 1。
在这里插入图片描述
Tips:
如果有代码题需要判断,该数是不是 2的k次方 ,运用 m = m & ( m - 1 )
这个表达式就可以轻松的判断,如果 m = m & ( m - 1 ) 等于0的话,那么该数就是 2的k次方。

2、求两个数二进制中不同位的个数

方法一

思路:将两个数字同时 &1(按位与1),如果得到的结果不相等,那么计数器 +1,循环32次
在这里插入图片描述
方法二

思路:运用按位异或操作符,对应的二进制位相同为 0 ,相异为 1,之后再计算按位异或后得到的二进制编码中有多少个 1 就OK了
在这里插入图片描述

3、打印二进制位的奇数位和偶数位

方法一
在这里插入图片描述

4、判断整数奇偶性

思路:scanf出错的时候会返回一个EOF
在这里插入图片描述

5、判断是元音还是辅音

方法一
思路:注意需要将缓冲区中的 ‘\n’ 用 getchar() 除去。
在这里插入图片描述
方法二

思路:在%c前面加上空格会跳过空白字符
在这里插入图片描述

小知识

1、无符号整型的原码、反码、补码相同
2、EOF - end of file :一个错误发生,或者遇到文件结束,scanf会返回EOF
3、EOF的本质是 -1,-1在内存中的补码是32个 1。
4、scanf 和 getchar 这样的函数是从缓冲区之中读取字符。
清理缓冲区曾在 初识C语言和循环有关的内容中 提到

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值