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语言和循环有关的内容中 提到
|