首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >整数中除前导零以外的零位数

整数中除前导零以外的零位数
EN

Stack Overflow用户
提问于 2010-06-20 23:34:38
回答 6查看 4.5K关注 0票数 4

如果我在Java中有一个整数,我如何计算除了前导零之外有多少位是零?

我们知道Java中的整数有32位,但是计算数字中设置位的数量,然后从32位中减去并不能得到我想要的结果,因为这也将包括前导零。

例如,数字5有一个零位,因为在二进制中它是101

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2010-06-20 23:37:10

要计算Java中的非前导零,可以使用以下算法:

代码语言:javascript
复制
public static int countNonleadingZeroBits(int i)
{
    int result = 0;
    while (i != 0)
    {
        if (i & 1 == 0)
        {
            result += 1;
        }
        i >>>= 1;
    } 
    return result;
}

如果您的输入通常很小,此算法将相当快,但如果您的输入通常是较大的数字,则在this page上使用其中一个位黑客算法的变体可能会更快。

票数 3
EN

Stack Overflow用户

发布于 2010-06-21 02:11:23

看一下Integer的API文档。

代码语言:javascript
复制
32 - Integer.numberOfLeadingZeros(n) - Integer.bitCount(n)
票数 7
EN

Stack Overflow用户

发布于 2010-06-20 23:39:41

计算数字中“位”的总数,然后从总位数中减去1的个数。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3079788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档