- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在做一些关于组合算法的练习,并试图弄清楚如何解决下面的问题:
给定一组 25 位,设置(选择)15(不可置换且顺序无关紧要):
n!/(k!(n-k)!) = 3.268.760
现在对于这些可能性中的每一种构造一个矩阵,我将每个唯一的 25 位成员与所有其他 25 位成员交叉,其中在它们之间的关系中,必须至少有 11 个公共(public)设置位(只有 1,没有 0)。
让我尝试将其表示为二进制数据,因此第一个成员将是:
0000000000111111111111111 (10 zeros and 15 ones) or (15 bits set on 25 bits)
0000000001011111111111111 second member
0000000001101111111111111 third member
0000000001110111111111111 and so on....
...
1111111111111110000000000 up to here. The 3.268.760 member.
现在将这些值交叉到 1 x 1 的矩阵上,我必须有 15 位公共(public)位。由于结果 >= 11,这是一个“有用”的结果。
对于 1 x 2,我们有 14 位公共(public)位,因此也是一个有效结果。
对所有成员执行此操作,最后,跨越 1 x 3.268.760 应该导致 5 位通用,因为它 < 11 它不是“有用的”。
我需要找出(通过数学或算法)覆盖所有具有 11 位公共(public)位的可能性所需的最少成员数。
换句话说,如果针对所有其他成员进行测试,一组 N 个成员可能在整个 3.268.760 x 3.268.760 宇宙中至少有 11 个共同位。
使用强力算法,我发现使用 81 个 25 位成员可以实现此目的。但我猜这个数字应该更小(接近 12)。
我试图使用强力算法在 3.268.760 上做出 12 个成员的所有可能变体,但可能性的数量它是如此之大,以至于需要一百多年的时间才能计算出来(3,156x10e69 组合)。
我在谷歌上搜索过组合数学,但有太多领域我不知道这些问题应该属于哪个领域。
因此,非常感谢有关组合学领域的任何指导,或针对这些问题的任何算法。
PS:仅供引用。两个成员的“相似度”使用以下方法计算:
(Not(a xor b)) and a
之后有一个小的递归循环来计算给定公共(public)位数的位数。
编辑:正如下面评论所 promise 的 (@btilly),这里是关系的“分形”图像 或 link to image
对于小于 10 位的值,色阶范围从红色(15 位匹配)到绿色(11 位匹配)到黑色。
此图像只是 4096 个第一组的样本。
最佳答案
tl;dr:你想解决 dominating set在一个大的、极其对称的图上。 btilly 是正确的,你不应该期待一个确切的答案。如果这是我的问题,我会尝试从贪心解决方案开始进行本地搜索。选择一组并尝试通过更改其他组来摆脱它。这需要数据结构来跟踪哪些集合恰好被覆盖一次。
编辑:好的,这里有一个更好的下限想法。对于从 1 到最优解的值的每个 k,都有一个下限 [25 选择 15] * k/[k 组的最大联合覆盖率]。你的边界 12(根据我的计算实际上是 10,因为你忘记了一些邻居)对应于 k = 1。证明草图:用 m 组修复一个任意解决方案并考虑 m 中的 k 可以获得的最大覆盖率。构建分数解,其中将所选 k 的所有对称性一起平均并缩放,以便每个元素都被覆盖一次。该解决方案的成本是 [25 选择 15] * k/[这 k 个集合的最大联合覆盖范围],它至少与我们所追求的下限一样大。但是,它仍然至少与原始 m 集解一样小,因为每个集的边际 yield 都在减少。
计算最大覆盖率通常很难,但是有一个因子 (e/(e-1))-approximation (≈ 1.58) 算法:greedy,听起来好像你可以快速实现(注意:你需要选择每次覆盖最多未覆盖的其他集合的集合)。通过将贪心解乘以 e/(e-1),我们得到了 k 个元素的最大覆盖范围的上限,这足以为上一段中描述的下限提供动力。
警告:如果这个上限大于[25选15],那么k就太大了!
关于algorithm - 找到最小的集合组以涵盖所有组合可能性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10077306/
是否可以在表格 View 中提供单独的单元格样式? 最佳答案 是的,看看几乎所有的苹果应用程序。他们倾向于使用不同控件的表格进行设置。这就是表格单元格具有不同重用标识符的原因。这样您就可以将正确的类型
我想知道是否可以在 Javascript 中做这样的事情: one(plus(nine())); // returns 10 看起来是这样,但我不确定如何将 one() 的值传递给 plus() 函数
我正在编写一个算法,在给定模型的情况下,我计算数据集列表的可能性,然后需要对每个可能性进行归一化(概率)。所以像 [0.00043, 0.00004, 0.00321] 这样的东西可能会被转换成 [0
我想检测是否可以进行局域网唤醒。 在我的路由器(Tomato 固件)上有一个包含信息的表格 - 当显示设备“事件(在 ARP 中)”时 - 可以通过 WOL(离线 Linux 电脑)打开该设备。 我想
我正在寻找一种方法来解析具有几个可能使用的不同终止字符的子字符串。我应该使用不同的方法还是有办法使用正则表达式来整理字符? 我当前的代码使用: smallstring = bigstring.subs
目前我有可能使用 surefire 插件在 maven 上运行多个测试,如下所示: mvn clean test -Dsurefire.suiteXmlFiles=test1.xml,test2.xm
最近,我成功地为 HDFS 和 YARN 启用了 HA。现在我有一个事件的和备用的名称节点,自动故障转移工作正常。我正在使用 Cloudera Manager 和 CDH 5。 我有以下问题。 例如,
我想要最简单的动词,它给出给定长度的所有 bool 列表的列表。 例如 f=. NB. Insert magic here f 2 0 0 0 1 1 0 1 1 f 3 0 0 0
这将是一个井字游戏实现: data Row = A | B | C deriving (Show, Read, Eq, Ord, Enum, Bounded) data Column = X
这是一个假设性的问题: 我想构建一个 Chrome 扩展程序,它会跟踪用户在该扩展程序处于事件状态的网页子集上的点击情况,并通过 AJAX 将数据作为 POST 或 GET 请求发送到我在某处运行的外
我们想使用 Entity Framework (.NET 4.0) 构建可以处理 Sql Server、MySQL 和 Oracle 的应用程序。也许 Sqlite 也是。 通过配置文件中的一些设置应
是否可以在 iPhone 上通过指定网络的 SSID 来创建数据连接? 是否可以从应用程序检查具有指定 SSID 的网络的信号/可用性? 问候,斯腾 最佳答案 遗憾的是,如果不使用私有(private
我正在使用各种 lambda 表达式语法测试性能差异。如果我有一个简单的方法: public IEnumerable GetItems(int point) { return this.ite
Effective Java 第 2 版的第 16 条,支持组合优于继承 说如下 “如果父类(super class)在后续版本中获得了一个新方法并且你运气不好给子类一个具有相同签名的方法和不同的返回
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我想知道 Tic Tac Toe 有多少种可能性,所以我在网上搜索并找到了一个数学定理,它表明 Tic Tac Toe 中有 255168 种可能的游戏。 网站:http://www.se16.inf
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我想在单个值中存储 4 个 boolean 可能性。例如,我想要一个单一的值来判断一个人是否: IsSingle IsGraduate IsMale IsLookingForPartner 那么将它们
我的 Wicket 口应用程序遇到了一些问题。 问题出在一个名为 OverviewPage 的页面上,这里有一些面板,例如 ListPanel,其中有我的 RepeatingView。 这个Repea
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 7年前关闭。 Improve this questi
我是一名优秀的程序员,十分优秀!