首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >面试问题

面试问题
EN

Stack Overflow用户
提问于 2014-01-06 17:15:28
回答 1查看 984关注 0票数 1

计算机科学的基础之一是知道数字是如何在2的补码中表示的。假设你用32位写下了A和B之间的所有数字,包括2的补码表示。你总共会写下多少个1?

输入:第一行包含测试用例的数量T (<=1000)。接下来的T行中的每行都包含两个整数A和B。

输出:输出T行,每个测试用例对应一行。

约束:-2^31 <= A <= B <= 2^31 -1

示例输入:

代码语言:javascript
复制
-2 0
-3 4
-1 4

示例输出:

代码语言:javascript
复制
63
99
37

说明:对于第一种情况,-2包含31个1,后跟一个0,-1包含32个1,0包含0,因此总数为63。对于第二种情况,答案是31 + 31 + 32 +0+1+1+2+1= 99

EN

回答 1

Stack Overflow用户

发布于 2014-01-06 17:32:08

代码语言:javascript
复制
for (int i=1; i<line[0]; i++)
{
    int numOf1s = 0;
    for (int j=line[i].A; j<=line[i].B; j++)
    {
        for (unsigned int n=j; n>0; n>>=1)
            numOf1s += n & 1;
    }
    printf("%d\n",numOf1s);
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20946558

复制
相关文章

相似问题

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