分享

每天一算法:「数学」位1的个数

 昵称11935121 2018-05-02

小编最近整理了一些经典面试题目清单,将帮助您掌握算法及数据结构,并提高您的编程能力。

编程能力就像任何其他技能一样,也是一个可以通过刻意练习提高的。

大多数经典面试题目都有多种解决方案。 为了达到最佳的练习效果,强烈建议您至少将题目练习两遍,如果可以的话,三遍会更好。

刻意练习并不意味着寻找答案并记住它,这种练习方法不是长久之计。 在没有参考答案情况下,越能自主解决问题,才越能提高自身能力。

题目通过率:40.3%,难度:简单

描述:

编写一个函数,输入是一个无符号整数,返回其二进制表达式中数字位数为 ‘1’ 的个数(也被称为汉明重量)。

示例 :

输入: 11输出: 3解释: 整数 11 的二进制表示为 00000000000000000000000000001011

示例 2:

输入: 128输出: 1解释: 整数 128 的二进制表示为 000000000000000000000000100000

每天一算法:「数学」位1的个数



解题思路:

此题解法思路很多,小编只提供一条思路:按位与运算符(&)

参加运算的两个对象,按二进制位进行“与”运算

运算规则:

0 & 0 = 0;0 & 1 = 0;1 & 0 = 0;1 & 1 = 1;

即 0& ?=0;1 & 1 = 1;

代码:

每天一算法:「数学」位1的个数

运算结果:

每天一算法:「数学」位1的个数

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多