剑指Offer面试题10(Java版):二进制中的1的个数
题目:请实现一个函数,输入一个整数。输出该数二进制表示中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的个数的更多相关文章
- 剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面
题目:输入一个整数数组.实现一个函数来调整该数组中数字的顺序.使得全部奇数位于数组的前半部分.全部偶数位于数组的后半部分. 1.基本实现: 假设不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,每 ...
- 【剑指Offer面试题】 九度OJ1371:最小的K个数
题目链接地址: http://ac.jobdu.com/problem.php?pid=1371 题目1371:最小的K个数 时间限制:1 秒内存限制:32 兆特殊判题:否提交:5938解决:1265 ...
- 剑指offer面试题3 二维数组中的查找(c)
剑指offer面试题三:
- 剑指offer 面试题43. 1~n整数中1出现的次数
leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(123 ...
- 剑指offer面试题3二维数组中的查找
题目: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 需要与面试官确认的是,这 ...
- 剑指offer——面试题10:斐波那契数列
个人答案: #include"iostream" #include"stdio.h" #include"string.h" using na ...
- 剑指offer面试题3 二维数组中的查找 (java)
注:java主要可以利用字符串的length方法求出长度解决这个问题带来方便 public class FindNum { public static void main(String[] args) ...
- 剑指Offer第36题—Java版
本题使用归并排序的思想,结合归并排序,写出的算法解. //数组中的逆序对 public static int InversePairs(int[] array){ if(array==null||ar ...
- 剑指offer 面试题10.2:青蛙变态跳台阶
题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级--它也可以跳上n级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 编程思想 因为n级台阶,第一步有n种跳法:跳1级.跳2级.到跳n级跳1级,剩下 ...
随机推荐
- Debian9 安装后的配置笔记
安装Debian9后,需要做的事,具体如下: 以下内容主要参考:https://www.cnblogs.com/OneFri/p/8308340.html感谢作者的分享. su 输入密码,登录root ...
- php函数,static,globalkeyword及三种变量作用域
函数 和js函数相似,关注php与其它语言不用的地方 函数的形參默认值 形式: function f($a,$b=3,$vc = "abc"){ } 注意:没有给默认值的形參必须传 ...
- color-在framwork中添加属性变量
1.今天在修改framwork中的代码的时候,需要把自己在代码中写的一个#ffffff,变成在xml中引用的变量.具体操作方法如下 1)在 frameworks/base/core/res/res/v ...
- Android 使用Wake Lock
为了延长电池的使用寿命,Android设备会在一段时间后使屏幕变暗,然后关闭屏幕显示,最后停止CPU.WakeLock是一个电源管理系统服务功能,应用程序可以使用它来控制设备的电源状态. WakeLo ...
- Android判断App是否在前台运行
版权声明:本文为博主原创文章,未经博主允许不得转载. //当前应用是否处于前台 private boolean isForeground(Context context) { if (context ...
- .condarc(conda 配置文件)
Configuration - Conda documentation .condarc以点开头,一般表示 conda 应用程序的配置文件,在用户的家目录(windows:C:\\users\\use ...
- angular设置全局变量,可修改监听变量
创建service.module.ts import { NgModule, ModuleWithProviders } from '@angular/core'; import { SomeShar ...
- VC6.0调试知识大全
VC6.0调试知识大全 分类: C++ 2010-09-06 21:33 7080人阅读 评论(5) 收藏 举报 debuggingmfcfunctionmenumicrosoftdll My Not ...
- hibernate 的映射文件快速生成:使用CodeSmith快速生成映射文件和映射类
一 CodeSmith简介 本文以表自动生成NHibernate的映射文件和映射类的实例来说明一下本软件的使用方法. CodeSmith是一种基于模板的代码生成工具,其使用类似于ASP.NET的语法来 ...
- 图解String类型的不可变性及其原因
1.String的不可变性 String s="abcd": 上面的语句定义了一个字符串变量s.该变量指向字符串"abcd",当初始化变量s时,会在堆中为s非配 ...