首页 > 其他 > 详细

[LintCode] Count 1 in Binary

时间:2015-08-15 10:18:06      阅读:1092      评论:0      收藏:0      [点我收藏+]

Count how many 1 in binary representation of a 32-bit integer.

Example

Given 32, return 1

Given 5, return 2

Given 1023, return 9

Challenge

If the integer is n bits with m 1 bits. Can you do it in O(m) time?

常规解法:

class Solution {
public:
    /**
     * @param num: an integer
     * @return: an integer, the number of ones in num
     */
    int countOnes(int num) {
        // write your code here
        int cnt = 0;
        while(num != 0){
            cnt += (num&1);
            num >>= 1;
        }
        return cnt;
    }
};

使用STL的解法: 

#include <bitset>
class Solution{
public:
/**
* @param num: an integer
* @return: an integer, the number of ones in num
*/
int countOnes(int num) {
// write your code here
bitset<sizeof(int)*8> bitvec(num);
return bitvec.count();
}
};

 

 

[LintCode] Count 1 in Binary

原文:http://www.cnblogs.com/changchengxiao/p/4731863.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!