- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是一道作业题,但我错过了讲师解释解决方案的讲座,我仍然无法弄清楚...
如果给定区间 [0,1] 中的 n 个实数(即 x1、x2、x3、...、xn),表明存在一种算法,该算法在最坏情况下线性时间运行,给出以下排列这n个数使得相邻数的差之和小于2。给出的提示是“buckets”。
最佳答案
嗯,你可以往这边走。将[0, 1]
分成k
段:[0, 1/k)
, [1/k, 2/k )
, ..., [(k-1)/k, 1]
。
你现在遍历你的列表并首先将所有适合第一个段的数字放入一个新列表,而不是适合第二个段的所有数字等等。这可以一次完成,所以 O(n)
。
考虑现在需要的金额是多少。同一段内数字的差异最多为1/k
,即差异的数量n-(k-1)
。其余 (n-1)
差异在相邻桶的数字之间,总共(清楚,为什么?)不超过 1
。总和受 (n-k+1)/k + (k-1)/k
约束。您可以使足够小的 k
足够大。
更多详情:
让我们将差异涂成两种颜色:同一部分的数字之间的差异涂成蓝色,不同部分的数字之间的差异涂成红色。由于排序,我们首先只有第 1 段中的数字(可能为 0),然后是第 2 段中的数字,依此类推。所以,我们首先有一些蓝色差异,然后是红色差异,然后又是几个蓝色差异,然后又是红色差异等。
让我们看看红色差异的数量是多少。显然不超过 k-1
红色差异,对吗?因为每一个红色的差异都是从一个段跳到更高的段。其余的差异是蓝色的。
现在,每个蓝色的差异不超过1/k
,因为被减数和减数来自同一个段。并且所有红色的差加起来(也就是它们的和!)不超过1。(暂时跳过其余部分,因为这是作业题。)
更正:
所有红色差异的总和不超过 2-2/k。这是为什么?好吧,走着瞧。在最坏的情况下,第一个红色差异可能是从某个段 A
的开头到某个其他段 B
的结尾。第二个是最坏的情况,从 B
的开始到其他一些段 C
的结尾。因此,在差异总和中,除了第一个和最后一个段外,每个段最多被计算两次。
关于给出数字排列的算法,使得相邻差异的总和小于 2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10124380/
问题:如果联接表的属性大于/小于值,是否可以在散列条件下进行测试 例如:测试 Actor 年龄是否大于年龄变量: 是否可以写而不是 ARRAY CONDITION 的: ageVariable = 3
这个问题已经有答案了: How to check if a number is between two values? (12 个回答) 已关闭 6 年前。 我目前正在 Codecademy 上学习
我想知道是否有一种方法可以比较 arrayList 中的连续元素。我有这个 for (int j=0; j< Index.size(); j++) { if(Index.get(j) < Ind
我正在压缩一些代码,现在我有 4 种方法,它们几乎都做同样的事情,除了 for 循环的建模有点不同。我正在传递 int 的 up , down , right ,和left作为这个紧凑方法的参数,这与
SELECT DISTINCT s.sname, s.sid FROM student s, class c WHERE s.programme = 'CS' AND s.level = '2' AN
我正在尝试通过命令行读取文件名, 这是教授要我们输入的命令: java MultiBinaryClient xxxxxx.edu 6001 < files.txt 我正在尝试使用 args[3]获取文
在 C# 中,您可能会看到以下内容: [] 或类似的行(但没有大于/小于符号): [assembly: AssemblyTitle("MyProject")] 我知道第一个称为属性(它有 gt 和 l
我只是想知道大于/小于的结果是如何计算并返回给高级语言的。 我在这里寻找硬件门模型。 让我们用一个统一的例子来解释,比如说5 > 3。 最佳答案 它通常通过带有进位检测的减法来实现。 从门控的角度来看
这个问题在这里已经有了答案: strange output in comparison of float with float literal (8 个答案) 关闭 8 年前。 案例一 float
你到底如何检查一个数字属性是否小于 Apache Ant? 从我所看到的(我是 Ant 的新手)你只能做 ? 最佳答案 您可以使用 (见 http://ant.apa
在 C 中使用 float.h 我想知道如何找到最大的数字,如果我加到 1,答案将保持为 1。 即 1 + x = 1 如何找到 x? 最佳答案 如果你想要“小于 FLT_EPSILON 的最大数字”
我正在尝试查询节点统计信息端点(_nodes / stats)并收到此错误: {"error":{"root_cause":[{"type":"illegal_argument_exception",
有没有更快的方法来检查列表中的项目是否大于、小于或等于某个数字? 或者你只需要循环它?我只是好奇是否有为此预先构建的函数。 示例: 列表包含 5、5、10、15、15、20。 我想检查是否有多少个
因此,我必须编写一个代码,从用户那里获取 2 个日期(月/日/年),如果第一个日期小于第二个日期,则返回“true”。在任何其他情况下,日期将为“假”或“它们是相同的”。我被告知我不能要求用户执行指定
我有两个变量,如果它们的值彼此相差在 5 个数字以内,我想触发一些代码。不知道哪个变量具有更高的值,我可以这样做: if (var1 > var2) { if ((var1 - var2) < 5
我有一个函数,它接受一个对象并将其转换为字节数组: public static byte[] serialize(Object obj) throws IOException { try(By
下载大小已经低于 4MB 的应用程序是否也可以作为免安装应用程序未经修改地分发? 最佳答案 要将该应用程序作为免安装应用程序提供,仍需采取一些步骤。参见 http://g.co/instantapps
我有以下 SELECT 但无法正常工作: SELECT COUNT(userid) FROM login WHERE 17 YEAR(DATE_SUB(NOW(), INTERVAL TO_DAYS
我制作了一个脚本,其中 #hsz-wrap2 附加到最后一个可见的 div,当 div 数量低于或等于 16 在 #snapshot_vertical div 内。 但是,if 条件的工作方式我不明白
我在外部的一排内放置了一个 Logo 、一个搜索框和一个语言栏,并位于 Bootstrap 导航栏上方。这一行当然仍在主容器中,但它包含我提到的 3 个元素——我和我的客户认为这 3 个元素独立于导航
我是一名优秀的程序员,十分优秀!