| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 415 人关注过本帖
标题:将int转binary代码中有个numberOfLeadingZeros 求具体解释下
取消只看楼主 加入收藏
ouyangshit
Rank: 3Rank: 3
来 自:China
等 级:论坛游侠
帖 子:155
专家分:107
注 册:2014-10-25
结帖率:100%
收藏
 问题点数:0 回复次数:3 
将int转binary代码中有个numberOfLeadingZeros 求具体解释下
程序代码:
public class BitTest {
    static void binaryPrint (int q) {
        if(q == 0) System.out.print(0);
        else {
            int nlz = Integer.numberOfLeadingZeros(q);
            q <<= nlz;
            for(int p = 0; p < 32 - nlz; p++) {
                int n = (Integer.numberOfLeadingZeros(q) == 0) ? 1 : 0;
                System.out.print(n);
                q <<= 1;
            }
        }
        System.out.println("");
    }   
2015-02-09 14:59
ouyangshit
Rank: 3Rank: 3
来 自:China
等 级:论坛游侠
帖 子:155
专家分:107
注 册:2014-10-25
收藏
得分:0 
numberOfLeadingZeros
public static int numberOfLeadingZeros(int i)
    在指定 int 值的二进制补码表示形式中最高位(最左边)的 1 位之前,返回零位的数量。如果指定值在其二进制补码表示形式中不存在 1 位,换句话说,如果它等于零,则返回 32。
    注意,此方法与基数为 2 的对数密切相关。对于所有的正 int 值 x:
        floor(log2(x)) = 31 - numberOfLeadingZeros(x)
        ceil(log2(x)) = 32 - numberOfLeadingZeros(x - 1)

    返回:
        返回在指定 int 值的二进制补码表示形式中最高位(最左边)的 1 位之前的零位的数量;否则,如果该值等于零,则返回 32。
2015-02-09 14:59
ouyangshit
Rank: 3Rank: 3
来 自:China
等 级:论坛游侠
帖 子:155
专家分:107
注 册:2014-10-25
收藏
得分:0 
看了api还是云里雾里
2015-02-09 15:00
ouyangshit
Rank: 3Rank: 3
来 自:China
等 级:论坛游侠
帖 子:155
专家分:107
注 册:2014-10-25
收藏
得分:0 
怎么这么冷清
2015-02-09 15:06
快速回复:将int转binary代码中有个numberOfLeadingZeros 求具体解释下
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.045542 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved