- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个方阵,其中每个单元格都是黑色或白色。设计一个算法来找到最大的子正方形,使得所有 4 个边框都是黑色的。
我有 O(n^2) 算法:
从左到右扫描每一列,对于每一列中的每个单元格,扫描每一行以找到具有后边框的最大子方 block 。
有更好的解决方案吗?
谢谢
最佳答案
O(n^2) 是可能的。我猜这是最佳选择,因为您有 n^2 个单元格。
请注意,任何正方形的左上角和右下角都位于同一条对角线上。
现在如果我们可以在 O(n) 时间内处理每条对角线,我们就会有一个 O(n^2) 时间算法。
假设我们有一个左上角的候选。我们可以计算它下方和右侧的连续黑色单元格的数量,并取两者中的最小值并将其称为 T。
对于右下角的候选,我们可以计算它左边和顶部的连续黑色单元格的数量,并取两者中的最小值,称之为 B。
一旦我们有了 T 和 B 这两个数字,我们就可以判断给定的左上角和右下角的候选是否真的给了我们一个全黑边框的正方形。
现在可以为每个单元格计算这两个数字,在 O(n^2) 时间内通过遍历整个矩阵四次(如何?)。
那么让我们假设这已经完成了。
现在考虑一条对角线。我们的目标是在 O(n) 时间内沿着这条对角线找到左上、右下对。
假设我们在数组 T[1...m] 中计算了 T,其中 m 是对角线的长度。类似地,我们有一个数组 B[1...m]。 T[1] 对应于对角线的左上端,T[m] 对应于右下角。与 B 类似。
现在我们按如下方式处理对角线,对于每个左上候选 i,我们尝试找到一个右下候选 j,它将给出最大的平方。注意 j >= i。另请注意,如果 (i,j) 是候选者,则 (i',j) 不是,其中 i' > i。
请注意,如果 T[i] >= j-i+1
且 B[j] >= j-i+1
,则 i 和 j 形成一个正方形。
即T[i] +i - 1 >= j
和 B[j] -j - 1 >= -i
。
因此我们形成新的数组,使得 TL[k] = T[k] + k -1
和 BR[k] = B[k] -k - 1
.
所以给定两个新数组 TL 和 BR,以及一个 i,我们需要回答以下问题:
What is the largest j such that TL[i] >= j and BR[j] >= -i ?
现在假设我们能够处理范围最大查询的 BR(可以在 O(m) 时间内完成)。
现在给定 TL[i],在 [i, TL[i]] 范围内,我们找到 BR 的最大值,比如 BR[j1]。
现在,如果 BR[j1] >= -i,我们在 [j1, TL[i]] 范围内找到 BR 的最大值,然后继续这种方式。
一旦我们找到 (TL[i],BR[j]) 候选者,我们就可以忽略 future i 的数组 BR[1...j]。
这使我们能够在 O(n) 时间内处理每个对角线,给出 O(n^2) 总算法。
我省略了很多细节并给出了草图,因为它已经太长了。请随时编辑此说明。
呼。
关于c++ - 在方阵中,每个单元格都是黑色或白色。设计一个算法来找到最大子正方形,使得所有 4 个边框都是黑色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8097377/
对于我正在使用的启动画面: setContentView(R.layout.activity_home); new Handler().postDelayed(new Runnable() {
这是我的问题。我有一个应用程序,它打开一个文件打开对话框,我试图将文件路径和文件名输入到“文件名:”组合框部分。 应用程序加载了您登录的表单。这将打开另一个表单,其中有许多按钮。选择其中一个按钮会打开
我正在使用 sjPlot 的 plot_model() 绘制回归模型。我想将我的线条颜色从 sjPlot 主题(红色和蓝色线条)更改为黑白或灰度。但是,当我使用 set_theme(theme_bw(
所以看起来SpriteMaterial的默认颜色是0xFFFFFF。这似乎意味着 Sprite 没有颜色。如果我将 Material 的颜色属性更改为 0xFF0000, Sprite 将显示为红色。
我需要在文档中找到最大的空白区域,并使用python在其中放置QR码,以显示其坐标,中心点和区域。 我认为OpenCV和Numpy应该足以完成此任务。 使用什么样的THRESH?由于扫描类型很多: 灰
Android 选项卡上的波纹效果默认为白色。我想在 tablayout 上添加波纹效果,但我的选项卡背景已经是白色的,并且波纹效果在其上不可见。 有没有办法改变 tabLayout 波纹效果的颜
我正在尝试在我的应用程序上显示一个基本的谷歌地图,但它不起作用,它显示一个白屏,即使我有网络连接,我也检查了我的 MANEFIST 一百次,我生成了一个 deubg key ,并确定它是是的 我想是否
我有一个带有框阴影的蓝色框,文本颜色为白色,如下所示: . 是否可以添加内阴影?喜欢this (jsfiddle)?它不适用于白色文本,就像我的示例一样。 body { /* This has t
这是我的代码: body{ background: url(https://static.pexels.com/photos/29628/pexels-photo.jpg) no-repeat
我已经从 w3school 实现了一个 slider 。我还从另一个例子中实现了这些点来跟踪幻灯片。如果我单击它们,它们工作正常,问题是我无法使当前/事件点(从实际位置的幻灯片)显示为纯白色,让你知道
我是 bootstrap 的新手,试图提高我的技能,我已经制作了 5 个盒子,如您所见(左侧两个,右侧 3 个),我的问题是为什么盒子编号“5”看起来不同,而不是相应的与数字 2 和 4 不在同一行,
我一直在研究一种导航,它会在滚动过标题后获得不透明度并缩小 Logo - 一切都很好,除了当导航栏覆盖白色背景上的段落时,它会变成透明并造成视觉困惑.我猜这可能是使用 rgba 的问题?我想保持不透明
有一个关于名为 Rockwell Std Light 的字体的问题。我在 Photoshop 中用蓝色背景显示白色文本,在 Dreamweaver 中也做了同样的事情。但是,网页中的字体总是看起来比较
我正在创建一个应用程序,它会在某个时候打开照片库。问题是照片库中的状态栏是黑色透明的,而我想要一个默认的应用程序(纯白色)。有什么办法可以改变它..? 我想补充一点,我试过这个:iOS SDK - H
我正在尝试使用 AForge.NET 来检测图像中的粗白线。 这就像我得到的管道一样,是应用阈值过滤器后我想要的结果。 我知道如何检测形状并且我已经在这样做了,但是这在任何形状下都不匹配,因为它没有边
我正在尝试让 Tabs 在 Android 上通过 compose 与 TabRow 一起使用。我想要的是 TabRow 有白色背景。 如文档 (https://developer.android.c
我已经为我的 Visual Studio 安装了最新的 WiX(安装程序),当我想设置图标时,它总是以空白结束。我正在尝试设置“所有 Windows 软件”中条目的图标 在下面的图片中你可以看到图标的
为什么选择后微调器文本会变成空白? 如果我使用 getActivity().recreate(),微调器文本会闪烁,然后变为空白;做出选择后。 我正在使用 recreate 根据微调器选择加载区域设置
我最近遇到了 的问题每当我滚动时,网站顶部/底部都会出现白色块 它更大一点。白色块是 的一部分正文背景 ,因为改变 body backgroundcolor 会使块也改变颜色。 我已经试过了设置 bo
我在 iOS7、iPhone 4 及更高版本的状态栏上遇到了一些问题。因为我的应用程序的背景是深色的,所以我需要状态栏是白色的,这样看起来不错。但是,当最小化应用程序、等待几秒钟并返回应用程序时,它会
我是一名优秀的程序员,十分优秀!