题目:请实现一个函数,输入一个整数。输出该数二进制表示中1的个数。

比如把9表示成二进制是1001,有2位是1。因此假设输入9。该函数输出2.

1、可能引起死循环的解法

这是一道非常主要的考察二进制和位运算的面试题。

题目不是非常难。面试官提出问题之后,我们非常快形成一个主要的思路:先推断证书二进制表示中最右边一位是不是1.接着把输入的证书右移一位,此时原来处于从右边树起的第二位被移到最后一位,再推断是不是1.这样没移动一位,知道整个整数变成0为止。如今的问题变成怎么推断一个整数的最右边是不是1了。

这非常easy,仅仅要把整数和1做位与运算看结果是不是0就知道了。1除了最右边的一位之外全部的位都是0.基于这个思路,我们非常快写出这种代码:

int numberOf1(int n)

{

int count = 0;

while(n!=0){

if(n & 1)

count++;

n = n>>1;

}

return count;

}

面试官看了 代码后可能会问:把证书右移一位和把整数除以2在数学上是等价的,那上面的代码中能够把右移换成除以2吗?答案是否定的。由于除法的效率比移位运算要低非常多,在实际编程中应尽可能地用移位运算取代乘除法。

面试官会问第二个问题就是:上面的函数假设输入一个负数,比方0x80000000,执行的时候会发生什么情况呢?把负数0x80000000右移一位的时候,并非简单地把最高位的1移到第二位变成0x40000000,而是0xC0000000.这是由于移位前是个负数,仍然保证移位是个负数,因此移位后的最高位会设为1.假设一直做右移位运算,终于这个数字会编程0xFFFFFFFF而陷入死循环。

2、常规解法:

为了避免死循环,我们能够不右移输入的数字n.首先把n和1做与运算,推断n的最低位是不是1.接着把1左移一位得到2,再和n做与运算,就能推断n的次低位是不是1。。。

这样重复左移,每次都能推断n的当中一位是不是1.基于这种思路,我们能够写出这种代码:

int number1(int n){

int count = 0;

int flag= 1;

while(flag ! =0){

if(n& flag)

count++;

flag =flag <<1;

}

return count;

}

这个解法中循环的次数等于二进制中的位数,32位的整数须要循环32次,以下我们再介绍一个算法。整数中有几个1就仅仅循环几次。

3、能给面试官带来惊喜的算法。

我们的分析就是:把一个整数减去1。再和原整数做与运算,会把该整数最右边的一个1变成0.那么一个整数的二进制表示中有多少个1,就能够进行多少次运算。基于这种思路。我们能够写出这种代码:

/**
*题目:实现一个函数,输入一个整数,输出该数二进制表示中的1的个数。 *比如把9改成二进制是1001,有2位是1.因此假设输入9。该函数输出2.
*/
package swordForOffer; /**
* @author JInShuangQi
*
* 2015年7月30日
*/
public class E10NumberOf1InBinary {
public int numberOf1(int num) {
int count = 0;
while (num != 0) {
count++;
num = num & (num - 1); }
return count;
} public static void main(String[] args) {
E10NumberOf1InBinary test = new E10NumberOf1InBinary();
System.out.println(test.numberOf1(9));
}
}

剑指Offer面试题10(Java版):二进制中的1的个数的更多相关文章

  1. 剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面

    题目:输入一个整数数组.实现一个函数来调整该数组中数字的顺序.使得全部奇数位于数组的前半部分.全部偶数位于数组的后半部分. 1.基本实现: 假设不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,每 ...

  2. 【剑指Offer面试题】 九度OJ1371:最小的K个数

    题目链接地址: http://ac.jobdu.com/problem.php?pid=1371 题目1371:最小的K个数 时间限制:1 秒内存限制:32 兆特殊判题:否提交:5938解决:1265 ...

  3. 剑指offer面试题3 二维数组中的查找(c)

    剑指offer面试题三:

  4. 剑指offer 面试题43. 1~n整数中1出现的次数

    leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(123 ...

  5. 剑指offer面试题3二维数组中的查找

    题目: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 需要与面试官确认的是,这 ...

  6. 剑指offer——面试题10:斐波那契数列

    个人答案: #include"iostream" #include"stdio.h" #include"string.h" using na ...

  7. 剑指offer面试题3 二维数组中的查找 (java)

    注:java主要可以利用字符串的length方法求出长度解决这个问题带来方便 public class FindNum { public static void main(String[] args) ...

  8. 剑指Offer第36题—Java版

    本题使用归并排序的思想,结合归并排序,写出的算法解. //数组中的逆序对 public static int InversePairs(int[] array){ if(array==null||ar ...

  9. 剑指offer 面试题10.2:青蛙变态跳台阶

    题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级--它也可以跳上n级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 编程思想 因为n级台阶,第一步有n种跳法:跳1级.跳2级.到跳n级跳1级,剩下 ...

随机推荐

  1. 洛谷 P1218 [USACO1.5]特殊的质数肋骨 Superprime Rib

    P1218 [USACO1.5]特殊的质数肋骨 Superprime Rib 题目描述 农民约翰的母牛总是产生最好的肋骨.你能通过农民约翰和美国农业部标记在每根肋骨上的数字认出它们.农民约翰确定他卖给 ...

  2. php函数symlink详解

    php函数symlink详解 建立符号链接 (symbolic link),类似于Windows里头常用的.lnk快捷方式 symlink语法: int symlink(string target, ...

  3. JQuery操作数组函数 push(),pop(),unshift(),shift()

    1.array.push() :在数组尾部添加新的元素,并返回新的数组长度. 2.array.unshift() :在数组头部添加新的元素,并返回新的数组长度.[听说IE浏览器不支持] 3.array ...

  4. JS截取字符串 charAt(),slice(),substring(),substr()

    1. charAt(i)输出指定下标的字母,长度为1,适用于把字符串切割成单个字符串. 2. slice() 和 substring() 都支持1-2个参数,第一个参数是开始位置,第二个参数是结束位置 ...

  5. ssi的使用 开启 配置等

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/lsfhack/article/details/69664402ssi的定义SSI(Server Si ...

  6. 通过 Microsoft iSCSI Software Target 提供存储服务

    软件下载地址: Microsoft iSCSI Software Target 3.3 下载完后成解压软件包如下: 安装官方的描述Target 端也就是服务端 只支持Windows Server 20 ...

  7. 记一次内存泄漏调试(memory leak)-Driver Monkey

    Author:DriverMonkey Mail:bookworepeng@Hotmail.com Phone:13410905075 QQ:196568501 硬件环境:AM335X 软件环境:li ...

  8. php spl标准库简介(SPL是Standard PHP Library(PHP标准库)(直接看代码实例,特别方便)

    php spl标准库简介(SPL是Standard PHP Library(PHP标准库)(直接看代码实例,特别方便) 一.总结 直接看代码实例,特别方便易懂 thinkphp控制器利眠宁不支持(说明 ...

  9. Topological Spaces(拓扑空间)

    拓扑空间的定义有多种形式,通过 open sets(开集)的形式定义是最为常见的拓扑空间定义形式. 1. 通过开集(open sets)定义 拓扑空间由一个有序对 (X,τ) 表示,X 表示非空集合, ...

  10. 【u247】生物进化

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 在一片茂密的原始森林中,生物学家们发现了几种远古时期的动物化石.他们将化石依次编号为1,2,3,--n ...