- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
此问题来自 2011 Codesprint (http://csfall11.interviewstreet.com/):
计算机科学的基础之一是了解数字如何用 2 的补码表示。想象一下,您使用 32 位以 2 的补码表示形式写下 A 和 B 之间的所有数字。你总共会写下多少个 1?输入:第一行包含测试用例数量 T (<1000)。接下来的 T 行中的每一行都包含两个整数 A 和 B。输出:输出 T 行,一个对应于每个测试用例。约束:-2^31 <= A <= B <= 2^31 - 1
示例输入:3个-2 0-3 4-1 4示例输出:639937
解释:对于第一种情况,-2 包含 31 个 1,后跟一个 0,-1 包含 32 个 1,0 包含 0 个 1。因此总数为63。对于第二种情况,答案是 31 + 31 + 32 + 0 + 1 + 1 + 2 + 1 = 99
我意识到您可以利用 -X 中 1 的数量等于 (-X) = X-1 的补码中 0 的数量这一事实来加快搜索速度。该解决方案声称存在用于生成答案的 O(log X) 递归关系,但我不明白。解决方案代码可以在这里查看:https://gist.github.com/1285119
如果有人能解释一下这种关系是如何推导出来的,我将不胜感激!
最佳答案
好吧,没那么复杂...
单参数 solve(int a)
函数是关键。它很短,所以我将其剪切并粘贴到这里:
long long solve(int a)
{
if(a == 0) return 0 ;
if(a % 2 == 0) return solve(a - 1) + __builtin_popcount(a) ;
return ((long long)a + 1) / 2 + 2 * solve(a / 2) ;
}
它仅适用于非负 a,它计算从 0 到 a
的所有整数中 1 的位数。
函数分为三种情况:
a == 0
-> 返回 0。显然。
a
even -> 返回 a
中 1 的位数加上 solve(a-1)
。也很明显。
最后一个案例很有趣。那么,我们如何统计1位从0到奇数a
的个数呢?
考虑 0 到 a
之间的所有整数,并将它们分成两组:偶数组和偶数组。例如,如果 a
为 5,则您有两组(二进制):
000 (aka. 0)
010 (aka. 2)
100 (aka. 4)
和
001 (aka 1)
011 (aka 3)
101 (aka 5)
注意这两组必须有相同的大小(因为a
是奇数并且范围是包含在内的)。要计算每组中有多少个 1 位,首先计算除最后一位以外的所有位,然后计算最后一位。
除最后几位外,所有内容如下所示:
00
01
10
...两个 组看起来都是这样。这里1的位数就是solve(a/2)
。 (在这个例子中,它是从 0 到 2 的 1 位数。另外,回想一下 C/C++ 中的整数除法舍入 。)
第一组中的每个数字的最后一位为零,第二组中的每个数字的最后一位为零,因此这些最后的位为总数贡献了 (a+1)/2
一位。
因此递归的第三种情况是 (a+1)/2 + 2*solve(a/2)
,适当转换为 long long
来处理a
为 INT_MAX
的情况(因此 a+1
溢出)。
这是一个复杂度为 O(log N) 的解决方案。要将其概括为 solve(a,b)
,您只需计算 solve(b) - solve(a)
,再加上处理负数的适当逻辑。这就是双参数 solve(int a, int b)
正在做的事情。
关于algorithm - 范围内整数的补码二进制表示中 1 的个数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7942732/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!