- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
该问题要求我们找出在 N*M 网格上放置 R 个硬币的方式的数量,使得每一行和每一列至少有一个硬币。给出的约束是 N , M < 200 , R < N*M。我最初想到回溯,但我意识到它永远不会及时完成。有人可以指导我找到另一个解决方案吗? (DP,封闭式公式。)任何指针都会很好。谢谢。
最佳答案
根据 OEIS sequence A055602一个可能的解决方案是:
Let a(m, n, r) = Sum_{i=0..m} (-1)^i*binomial(m, i)*binomial((m-i)*n, r)
Answer = Sum_{i=0..N} (-1)^i*binomial(N, i)*a(M, N-i, R)
您需要计算 a 的 N+1 个不同值。
假设您已经预先计算了二项式系数,a 的每个评估都是 O(M),因此总复杂度是 O(NM)。
这个公式可以使用inclusion-exclusion principle推导出来两次。
a(m,n,r) 是将 r 个硬币放在大小为 m*n 的网格上的方式的数量,使得 m 列中的每一列都被占用,但不一定所有行都被占用。
包含-排除将其转化为正确答案。 (这个想法是我们从 a(M,N,R) 中得到我们的第一个估计。这高估了正确答案,因为不是所有的行都被占用所以我们减去只占用 N 的情况 a(M,N-1,R) -1 行。这会低估所以我们需要再次更正...)
类似地,我们可以通过考虑 b(m,n,r) 来计算 a(m,n,r),这是将 r 个硬币放置在我们不关心行或列被占用的网格上的方法的数量.这可以简单地从在网格大小 m*n 中选择 r 个位置的方法的数量得出,即二项式 (m*n,r)。我们使用 IE 将其转换为函数 a(m,n,r),我们知道所有列都已被占用。
如果您想对每个方 block 上的硬币数量允许不同的条件,那么您只需将 b(m,n,r) 更改为适当的计数函数即可。
关于algorithm - 计算将硬币放在网格上的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11635567/
我当前项目中的许多类都有几个只能从类本身内部调用的属性和方法。此外,根据类(class)的当前状态,它们可能会扰乱类(class)的工作。 目前,所有这些接口(interface)都在 .h 文件的主
我想使用ngbTabSet将nav-pills in card-header 和tab-content in card-body。但我不知道该怎么做。 这是我尝试实现的示例(使用 bootstrap.
我正在浏览文档以查找如何允许放置在停靠栏图标上。据我所知,建议您使用 LSItemContentTypes,因为 CFBundleTypeOSTypes 已弃用。但是,我无法让 LSItemConte
我正在尝试在书签中使用 jquery UI 作为 slider 。并且 jquery ui 要求在普通 jquery 文件之后包含该文件。 所以到目前为止我所尝试的只是将脚本附加到 header ,同
您好,我尝试了广泛的谷歌搜索,但似乎没有任何帮助。 这是我的场景: 公司 Logo 存储在外部域/网址(矩形)中。 带有谷歌地图的 Ionic 应用程序,将这些 Logo 作为标记放置在 map 上。
我今天在阅读我的一些 C# 代码时发现了这一行: if (ProgenyList.ItemContainerGenerator.Status != System.Windows.Controls.Pr
我刚遇到this question在 Go FAQ 中,它让我想起了困扰我一段时间的事情。不幸的是,我真的不明白答案是什么。 似乎几乎所有非 C 类语言都将类型放在变量名之后,如下所示: var :
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
我有两本 T.Parr 写的关于 ANTLR 的书,我到处都看到美元符号和符号的引用。它也对我有用: term : IDENT -> { new TokenNode($IDENT) }; 或更复杂的东
我在实现段控制时遇到了一些问题。因为我希望它是一个固定的标题,所以当我滚动时我总是可以看到它,我已经在 - (UIView *)tableView:(UITableView *)tableView v
我有一个 20x36px (10x18pt) 的箭头图像,当我选择一个 UIImageView 时,将它拖到我的 View Controller 上然后设置图像,它总是模糊的。我只在我的项目中包含 @
How can I put background image when I hover a link Insert Bg in this a when hov
我需要在我的 .container 中添加(最新的第一个)新分区,但在 .controls (按钮)之后。可能吗? 注意:添加新的分区来保存按钮下方的前置控件对我来说不是一个选择。 HTML 需要保持
我是一名优秀的程序员,十分优秀!