算法题每日一练---第47天:出现1的个数

简介: 编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 1 的个数。

1.png

一、问题描述

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


题目链接:出现1的个数


二、题目要求


样例 1

输入:00000000000000000000000000001011输出:3解释:输入的二进制串00000000000000000000000000001011中,共有三位为'1'


样例 2

输入:00000000000000000000000010000000输出:1解释:输入的二进制串00000000000000000000000010000000中,共有一位为'1'


考察

1.位运算简单题型
2.建议用时5~20min


三、问题分析


本题是位运算的第2题,没了解过位运算相关知识点可以看这一篇文章,讲解比较详细:

算法题每日一练---第45天:位运算


计算1的个数,我们可以使用位运算当中的与,与运算就是只有两个都为1,最终结果才为1。比如:

1001&1100=1000。

计数排查的话,可以使用位运算里面的左移运算,通过移位32次进行判断是否包含1,如果包含的话,计数器就+1。


拓展

  • 题目中的uint32_t代表32位无符号类型


四、编码实现


classSolution {
public:
inthammingWeight(uint32_tn) {
inti,ans=0;//初始化定义for(i=0;i<32;i++)//32位无符号类型        {
if(n&(1<<i))//位运算的与和左移运算            {
ans++;//计数器++            }
        }
returnans;//输出结果    }
};


五、测试结果11.png

相关文章
|
算法
算法题每日一练---第60天:快速幂
快速幂是一种简单而有效的小算法。
167 15
算法题每日一练---第60天:快速幂
|
存储 算法
算法题每日一练---第61天:数的幂次
给定三个正整数 N、M、P,求解N^MmodP的具体值。
117 8
算法题每日一练---第61天:数的幂次
|
存储 算法 测试技术
算法题每日一练---第62天:Pow(x, n)
实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,x^n)
182 6
算法题每日一练---第62天:Pow(x, n)
|
算法
算法题每日一练---第58天:错误的集合
集合 s 包含从 1 到 n 的整数。
151 2
算法题每日一练---第58天:错误的集合
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
171 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
140 1
算法题每日一练---第76天:丑数 l
|
算法 C++
算法题每日一练---第67天:无重复字符的最长子串
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
117 0
算法题每日一练---第67天:无重复字符的最长子串
|
算法
算法题每日一练---第65天:螺旋矩阵 II
给你一个正整数 n ,生成一个包含 1 到 n2 所有元素
108 1
算法题每日一练---第65天:螺旋矩阵 II