- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在创建一个计数算法,在该算法中,我以更大的增量增加数字,然后随着时间的推移增量变小,理想情况下达到零或 1。最终的总和值应该是预定义的。步骤数应该是一个输入参数并且可以变化。它似乎是一个具有最大值的对数函数。然而,对数函数会增长到无穷大。
我发现最好的是对数的平方根:
val log = (1..10).map { Math.sqrt(Math.log(it * 1.0)) }
val max = log.max()
val rounded = log.map { it * 1000 / max!! }.map { Math.round(it) }
rounded.forEachIndexed { i, l ->
if (i + 1 < rounded.size)
println("${rounded[i + 1] - rounded[i]}")
}
但是,我最终还是没有得到非常小的增量。如果范围是从 0 到 10: 549、142、85、60、46、37、31、27、23
如果范围是 20:481、125、74、53、40、33、27、23、21、18、16、14、14、12、11、10、10、9、9
最后用什么算法得到1?
更新:基于 Patricks 公式,我做了这个解决方案:
` val N = 18981.0
val log = (1..50).map { N - N/it }
val max = log.max()
log.map { print("$it, ") }
val rounded = log.map { it * N / max!! }.map { Math.round(it) }`
重要的是 N
是 Double
而不是整数
最佳答案
对数的平方根也增长到无穷大。尝试
f(n) = N - N/n
这在 n = 1 时具有值 0,并且随着 n 无限增长而趋向于 N。如果您需要更精细的粒度,请添加一些系数并尝试使用它们,直到获得合理的值。例如,您可以使用 [1 + (n/1000)] 并获得类似但慢得多的增长。您还可以使用 exp(-x)
或任何具有水平渐近线的函数并获得类似的行为。
f(n) = N - exp(-n)
同样,添加一些系数,看看函数如何变化
关于algorithm - 快速增加并减慢达到预定义最大值的功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54696759/
我对我接管的项目有疑问。我正在转换其他人编写的 MS Access 应用程序并将其转换为 MySQL/PHP Web 应用程序。其中大部分已经完成,但是,当涉及到此应用程序的调度部分时,我处于停滞状态
我有一个带有 @Scheduled 注释的方法。此方法包含长时间运行、昂贵的操作。我担心当计划的方法开始运行时应用程序会变慢。有什么办法可以为预定方法分配优先级吗?在 Spring 中启动低优先级后台
我的大学有一个预订项目房间的网站;但除非你很幸运或者半夜醒着,否则要订到房间并不容易。因此,我编写了一个 JS 片段来填写所有必要的字段并提交表单。 但是我如何自动化这个过程呢? 我的目的基本上是加载
我正在评估处理大量排队消息的可能解决方案,这些消息必须在特定日期和时间交付给工作人员。执行它们的结果主要是对存储数据的更新,它们最初可能是也可能不是由用户操作触发的。 例如,想想你在一个假设的大型星际
@Scheduled documentation here声明 fixedRateString值可以是 the delay in milliseconds as a String value, e.g
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我有一个有趣的情况。我解析了几个新闻发布网站,想通过调度程序将它们保存到数据库中。但是保存时出现错误。由于交易后写条件 described here . 我的模型类是 @Entity @Table(n
我正在阅读 Java Concurrency in Practice 并遇到以下代码片段。 public static void timedRun(final Runnable r,
使用 Azure 数据工厂,是否可以对驻留在 Azure SQL 数据库中的多个(不是全部)表中的所有行执行预定的 1:1 复制/克隆到另一个 Azure SQL 数据库(在本例中为 Azure SQ
我是一名优秀的程序员,十分优秀!