- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
如果你有一个由 1 和 0 组成的二进制矩阵,并且你可以切换列(将列中的所有 1 更改为 0,将所有 0 更改为 1),你如何找到“纯”行的最大数量对于列切换的所有可能组合?“纯”表示该行全为 0 或全为 1。
例如:
1 0
1 0
1 1
您可以切换任一列以获得 2 行“纯”,这是您能做的最好的(切换两者并不更好),因此您返回 2(“纯”行的最大数量)。
我似乎想不出一个有效的方法来做到这一点。到目前为止,我得到的唯一方法是使用一堆循环和蛮力,并通过检查一行的总和是 0(全 0)还是 N(一行中的元素数)来检查相同性。
最佳答案
在 OP 澄清后,最大纯行问题是找到切换后变为 00...0 或 11...1 的最大行数。我已经相应地更新了我的解决方案。
请注意,我们有以下事实:
如果两行 ri 和 rj 在切换后减少为纯行,那么我们必须有 ri = rj 开始。
如果 ri ≠ rj 且 ri 与 rj 重叠(即它们对应的某些列相同),则它们都不能映射到纯行。
以上两个事实都直接来自以下观察:
Max number of "pure" rows is the same as the max number of identical rows
我们声称构成最大纯问题解的所有行在矩阵 M 中必须相同。
假设我们有一个 m×n 矩阵 M,并且我们找到了最大纯行问题的解。令行 ri 和 rj 是两个任意行,它们在切换后减少为纯行。
观察在对列进行所有必要的切换操作之后(用 σ1、σ2 表示, ..., σk), ri 和 rj 都是“纯”行。即我们有以下内容:
σ1(σ2(...(σk(ri)...)) = σ1(σ2(...(σk(rj)...)) = 00...0
或
σ1(σ2(...(σk(ri)...)) = σ1(σ2(...(σk(rj)...)) = 11...1
因此,在应用所有这些切换操作后,ri 和 rj 将彼此相等。如果我们撤消最后一次切换(即我们切换这些行的相同列条目),显然 ri 和 < em>rj 仍将映射到相同的输出。即我们有以下内容:
σ2(σ3(...(σk(ri)...)) = σ2(σ3(...(σk(rj)...))
如果我们继续撤消切换操作,我们可以得出结论 ri = rj。换句话说,如果您从最大纯问题的解决方案中选择任意行,这些行在开始时必须相同。
给定一行 ri,如果它可以简化为纯行,比如 00...0,那么我们知道另一行 r如果 ri 与 rj j 不能减少到 11...1 sub>(来自上面的事实 2)。我们只能希望与 ri 不重叠的另一行 rk 减少到 11.. .1.
根据前面的思路,我们可以有如下简单的算法来解决最大纯行问题。
我们首先扫描矩阵 M 的行,然后找到矩阵的所有 unique 行(用 s1 表示,s 2, ..., sk)。我们让count(si)
表示 si 在 M 中出现的次数。然后我们遍历所有对 (si, sj) 以确定最大纯行号,如下所示:
int maxCount = 0;
for each row si:
for each sj ≠ si:
if (sj overlaps si)
continue;
else
if (count(si) + count(sj) > maxCount)
// We have found a better pair
maxCount = count(si) + count(sj);
return maxCount;
我们正在做O(n)
在内部 for 循环中工作(用于逐项检查两行是否重叠),循环结束 O(m<sup>2</sup>)
最坏情况下的行,所以算法的运行时间是O(nm<sup>2</sup>)
.
关于algorithm - 在给定二进制 MxN 矩阵和切换列的能力的情况下最大化行相同性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26694882/
我到处搜索 .net 3.0 和 3.5 框架的内容列表,因为我一直在使用哈希表等旧技术而不是字典(较新的技术)进行编程。 我一直在犹豫,想知道在哪里可以找到 C# 和 .Net 框架的所有最新功能的
你好我有一个非常不寻常的问题,因为我认为在我的情况下工作流运行时没有使用足够的 CPU 能力。场景如下: 我向队列发送了很多消息。我使用 WorkflowRuntime 类中的 EnqueueItem
我正在为 OSX 图像处理应用程序编写一个插件接口(interface)。它的设计理念是插件应该尽可能简单,以便开发人员可以在看到示例代码后几分钟内进入并编写效果。为此,这些示例不需要或使用 XCod
...或者必须抛出异常才能影响性能? 引用已接受的答案here .这是我想要实现的东西,如果以这种方式创建实例不会使事情变得非常慢的话。 (我每秒要创建数千个对象,粒子系统等。所以不,考虑到在 Jav
我必须开发 C API 来通过 UI APPLICATION 使用重启功能而不是系统调用和 exec 功能来关闭 linux 系统。 This reboot link说为了运行这个函数调用者必须有 C
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
Droid SDK 是否支持手指在屏幕上滑动返回上一屏幕,而不是使用返回键? 最佳答案 我假设你的意思是“滑动”作为 i-phone 的解锁系统。 返回上一屏幕没有内置任何东西..用于实现手指检测实现
我无法理解 Michael Hartl 的 Ruby on Rails 教程中“记住我”的实现。他创建了一个带有登录方法的 SessionsHelper 模块,其中包含以下内容: module Ses
近日,华为 分析服务 6.9.0版本发布,正式上线 探索能力 。开发者可自由定义与配置分析模型,支持报告实时预览,数据洞察体验更加灵活与便捷. 新上线的探索能力中,有漏斗分析、事件归因、会话路径分析
给定一个带有属性“日期”的 Rails 模型“Widget”,是否可以在要求日期晚于当前时间的 CanCan 操作授权上设置条件? documentation显示如何指定数字属性的范围: can :r
我有兴趣将 CPU 密集型 Web 应用部署到 Azure 应用服务实例。我找不到有关 Azure 应用服务的 CPU 使用率和/或限制的任何详细信息。我担心的是,如果不深入了解应用程序的 CPU 规
我的场景: 我导航到登录页面。我输入了一个已知的用户名和一个错误的密码。ZAP 没有发现任何问题。 我选择 POST 到登录页面。我找到包含用户名和密码的行。密码:ctl00%24ContentPla
我是 Laravel 的新手,我曾经在 codeigniter 上工作。我对 Eloquent ORM 的概念着迷。我有一个关于 Eloquent 能力的一般性问题。ORM的能力是什么,我的意思是我们
我正在尝试运行 Java Jetty 应用程序,但我一直看到此错误: Caused by: org.postgresql.util.PSQLException: ERROR: function cry
我正在创建一个 UITableView,我将在其中加载并显示博客提要中的数据。该数据将每天、在启动时或动态更新。 我想要做的是为此屏幕提供一些离线功能,这样如果用户没有连接到互联网,他仍然可以看到 V
我使用 ChromeDriver 2.33 和 WebDriver 3.6.0 并尝试设置文件下载的默认目录。 Map prefs = new HashMap(); prefs.put("downlo
我想知道 Java 是否有任何方法可以提示用户输入管理密码,就像他们使用 sudo 时那样,这样我就可以在 Java 程序中运行命令,而不必对系统或 Sudoers。我已经看到在 Python 中完成
Apple Pay 权利/能力仅在 App Store 中有效。我将在 App Store 和 Enterprise 中发布此应用。 如果选择了 App Store Release 方案,我希望 Xc
我正在研究 termcap 库。我正在尝试在终端中做一个行编辑器。我有一个可以在线移动的光标。一条线一切都很好。但是,如果我的行大于终端宽度,我无法使用 le 命令(将光标向左移动)将光标从第二行返回
我有时用 Java 编写代码,我注意到有时它在多核机器上使用超过 100% 的 CPU。我现在在一台有 33 个 CPU(亚马逊的 EC2)的多核机器上运行一些代码,我想让我的 Java 进程使用所有
我是一名优秀的程序员,十分优秀!