题目:请实现一个函数,输入一个整数。输出该数二进制表示中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. TextView-shadow 阴影实现

    直接上代码 1)实现普通效果 <TextView android:layout_width="match_parent" android:layout_height=&quo ...

  2. 109.vprintf vfprintf vscanf vfscanf

    vprintf //输出到屏幕 int POUT(char *str, ...) { va_list arg_p=NULL; //读取 va_start(arg_p, str); //接受可变参数 i ...

  3. C# List 复制克隆副本

    [C#技术] C# List 复制克隆副本数字人 发表于:2012-8-28 18:02:49废话不多说,看代码: 方法一: List<string> t = new List<st ...

  4. 哈夫曼树的介绍 ---java实现

    一.     什么是哈夫曼树 是一种带权路径长度最短的二叉树,也称最优二叉树 带权路径长度:WPL=(W1*L1+W2*L2+W3*L3+...+ Wn*Ln) N个权值Wi(i=1,2,...n)构 ...

  5. 如何安装Python环境以及为Visual Studio 2012安装Python插件

    (一)首先,我机器上的开发环境安装的是Visual Studio 2012版本,系统为window7,64位,要安装的Python版本为python3.4-x64,双击安装包安装Python环境,需要 ...

  6. [D3] Create Chart Axes with D3 v4

    Most charts aren’t complete without axes to provide context and labeling for the graphical elements ...

  7. Android开发系列(二十):AutoCompleteTextView(自己主动完毕文本框)的功能和使用方法

    当用户输入一定的字符之后,自己主动完毕文本框可以显示一个下拉菜单,供用户从中选择,当用户选择某个菜单项之后,AutoCompleteTextView可以依照用户的选择自己主动填写该文本框 AutoCo ...

  8. MySql基本的语法(学习笔记)

    MySQL语法大全_自己整理的学习笔记 select * from emp;  #凝视 #--------------------------- #----命令行连接MySql--------- #启 ...

  9. Linux平台Makefile文件的编写基础篇

    目的:        基本掌握了 make 的用法,能在Linux系统上编程. 环境:        Linux系统,或者有一台Linux服务器,通过终端连接.一句话:有Linux编译环境. 准备: ...

  10. stm32的串口中断

    下面有很多问题没有验证: 在设置USART_CR1中的TE位时,会发送一个空闲帧作为第一次数据发送, 目前我所了解的串口中断发送,有两种方式: 一个是:TC 一个是:TXE 这是判断两个标志位, 第一 ...