2024-02-28:用go语言,有一个由x轴和y轴组成的坐标系,

"y下"和"y上"表示一条无限延伸的道路,"y下"表示这个道路的下限,"y上"表示这个道路的上限,

给定一批长方形,每一个长方形有(x1, x2, y1, y2),4个坐标可以表示一个长方形,

判断这条道路整体是不是可以走通的。

以下为正式题目:

图片在计算机处理中往往是使用二维矩阵来表示的,

给你一个大小为 m x n 的二进制矩阵 image 表示一张黑白图片,0 代表白色像素,1 代表黑色像素,

黑色像素相互连接,也就是说,图片中只会有一片连在一块儿的黑色像素。像素点是水平或竖直方向连接的。

给你两个整数 x 和 y 表示某一个黑色像素的位置。

请你找出包含全部黑色像素的最小矩形(与坐标轴对齐),并返回该矩形的面积。

你必须设计并实现一个时间复杂度低于 O(m*n) 的算法来解决此问题。

输入:image = [[“0”,“0”,“1”,“0”],[“0”,“1”,“1”,“0”],[“0”,“1”,“0”,“0”]], x = 0, y = 2。

输出:6。

答案2024-02-28:

来自左程云

灵捷3.5

大体步骤如下:

1.定义一个辅助函数minArea(image [][]byte, x int, y int) int,用于计算包含全部黑色像素的最小矩形的面积。

2.在minArea函数中,使用二分查找来确定矩形的左边界、右边界、上边界和下边界。

3.实现辅助函数left(image [][]byte, col int) int,用于确定左边界。采用二分查找方法,在给定的列col中向左查找,直到找到第一个出现黑色像素的位置。

4.实现辅助函数right(image [][]byte, col int) int,用于确定右边界。采用二分查找方法,在给定的列col中向右查找,直到找到最后一个出现黑色像素的位置。

5.实现辅助函数up(image [][]byte, row int, left int, right int) int,用于确定上边界。采用二分查找方法,在给定的行row中从左边界到右边界之间查找,直到找到第一个出现黑色像素的位置。

6.实现辅助函数down(image [][]byte, row int, left int, right int) int,用于确定下边界。采用二分查找方法,在给定的行row中从左边界到右边界之间查找,直到找到最后一个出现黑色像素的位置。

7.在minArea函数中,调用辅助函数获取左边界、右边界、上边界和下边界,并计算矩形的面积((right - left + 1) * (down - up + 1))。

8.在main函数中,定义一个示例图片image和给定的点(x, y),调用minArea函数并将结果打印出来。

总的时间复杂度:由于每个辅助函数都采用了二分查找的方法,时间复杂度为O(logn),所以总的时间复杂度为O(logn)。

总的额外空间复杂度:除了存储输入数据和输出结果的额外空间外,代码没有使用其他额外的空间,因此总的额外空间复杂度为O(1)。

go完整代码如下:

package main

import "fmt"

func minArea(image [][]byte, x int, y int) int {
left := left(image, y)
right := right(image, y)
up := up(image, x, left, right)
down := down(image, x, left, right)
return (right - left + 1) * (down - up + 1)
} func left(image [][]byte, col int) int {
l, r, m, ans := 0, col-1, 0, col
find := false
for l <= r {
m = (l + r) / 2
find = false
for i := 0; i < len(image); i++ {
if image[i][m] == '1' {
find = true
break
}
}
if find {
ans = m
r = m - 1
} else {
l = m + 1
}
}
return ans
} func right(image [][]byte, col int) int {
l, r, m, ans := col+1, len(image[0])-1, 0, col
find := false
for l <= r {
m = (l + r) / 2
find = false
for i := 0; i < len(image); i++ {
if image[i][m] == '1' {
find = true
break
}
}
if find {
ans = m
l = m + 1
} else {
r = m - 1
}
}
return ans
} func up(image [][]byte, row int, left int, right int) int {
u, d, m, ans := 0, row-1, 0, row
find := false
for u <= d {
m = (u + d) / 2
find = false
for i := left; i <= right; i++ {
if image[m][i] == '1' {
find = true
break
}
}
if find {
ans = m
d = m - 1
} else {
u = m + 1
}
}
return ans
} func down(image [][]byte, row int, left int, right int) int {
u, d, m, ans := row+1, len(image)-1, 0, row
find := false
for u <= d {
m = (u + d) / 2
find = false
for i := left; i <= right; i++ {
if image[m][i] == '1' {
find = true
break
}
}
if find {
ans = m
u = m + 1
} else {
d = m - 1
}
}
return ans
} func main() {
image := [][]byte{{'0', '0', '1', '0'}, {'0', '1', '1', '0'}, {'0', '1', '0', '0'}}
x := 0
y := 2
result := minArea(image, x, y)
fmt.Println(result)
}

python代码如下:

# -*-coding:utf-8-*-

def minArea(image, x, y):
left = left_boundary(image, y)
right = right_boundary(image, y)
up = upper_boundary(image, x, left, right)
down = lower_boundary(image, x, left, right)
return (right - left + 1) * (down - up + 1) def left_boundary(image, col):
l, r, m, ans = 0, col-1, 0, col
find = False
while l <= r:
m = (l + r) // 2
find = False
for i in range(len(image)):
if image[i][m] == '1':
find = True
break
if find:
ans = m
r = m - 1
else:
l = m + 1
return ans def right_boundary(image, col):
l, r, m, ans = col+1, len(image[0])-1, 0, col
find = False
while l <= r:
m = (l + r) // 2
find = False
for i in range(len(image)):
if image[i][m] == '1':
find = True
break
if find:
ans = m
l = m + 1
else:
r = m - 1
return ans def upper_boundary(image, row, left, right):
u, d, m, ans = 0, row-1, 0, row
find = False
while u <= d:
m = (u + d) // 2
find = False
for i in range(left, right+1):
if image[m][i] == '1':
find = True
break
if find:
ans = m
d = m - 1
else:
u = m + 1
return ans def lower_boundary(image, row, left, right):
u, d, m, ans = row+1, len(image)-1, 0, row
find = False
while u <= d:
m = (u + d) // 2
find = False
for i in range(left, right+1):
if image[m][i] == '1':
find = True
break
if find:
ans = m
u = m + 1
else:
d = m - 1
return ans image = [['0', '0', '1', '0'], ['0', '1', '1', '0'], ['0', '1', '0', '0']]
x = 0
y = 2
result = minArea(image, x, y)
print(result)

2024-02-28:用go语言,有一个由x轴和y轴组成的坐标系, “y下“和“y上“表示一条无限延伸的道路,“y下“表示这个道路的下限,“y上“表示这个道路的上限, 给定一批长方形,每一个长方形有(的更多相关文章

  1. Java 单文件、多文件上传 / 实现上传进度条

    博客地址:https://ainyi.com/76 日常,工作 在这里总结一下上传吧(是以前做过的练习,就汇总到个人博客吧) java ssm 框架实现文件上传 实现:单文件上传.多文件上传(单选和多 ...

  2. WInform中实现设置ZedGraph中曲线的X轴与Y轴的上限与下限

    场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...

  3. 解决iPhone上select时常失去焦点,随意跳到下一个输入框,影响用户操作

    window.addEventListener('load', function() { FastClick.attach(document.body); }, false); //300s延迟,解决 ...

  4. 编写一个程序,开启 3 个线程,这三个线程的 ID 分别为 A、B、C,每个线程将自己的 ID 在屏幕上打印 10 遍,要求输出的结果必须按顺序显示。如:ABCABCABC…… 依次递归

    import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.uti ...

  5. 梦想MxWeb3D协同设计平台 2019.02.28更新

    梦想MxWeb3D协同设计平台 2019.02.28更新 SDK开发包下载地址: http://www.mxdraw.com/ndetail_10130.html 在线演示网址: http://www ...

  6. 用阿里官网提供的plupload oss的web直传,视频上传进行前端验证它的时长,尺寸,大小等。替换上一个不需要的单个视频

    accessid = '' accesskey = '' host = '' policyBase64 = '' signature = '' callbackbody = '' filename = ...

  7. Winform中设置ZedGraph鼠标悬浮显示举例最近曲线上的点的坐标值和X轴与Y轴的标题

    场景 Winform中设置ZedGraph鼠标双击获取距离最近曲线上的点的坐标值: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/ ...

  8. Codeforces Round #450 (Div. 2) A. Find Extra One【模拟/判断是否能去掉一个点保证剩下的点在Y轴同侧】

    A. Find Extra One time limit per test 1 second memory limit per test 256 megabytes input standard in ...

  9. echarts修改X,Y轴上的颜色

     分为2.0和3.0 一.2.0 修改的代码: x轴: xAxis : [ { type : 'category', data : ['<30','30-','40-','50-','60-', ...

  10. Highcharts属性与Y轴数据值刻度显示Y轴最小最大值

    Highcharts 官网:https://www.hcharts.cn/demo/highcharts Highcharts API文档:https://api.hcharts.cn/highcha ...

随机推荐

  1. [转帖]iptables命令详解和举例(完整版)

    1.防火墙概述 防火墙,其实说白了讲,就是用于实现Linux下访问控制的功能的,它分为硬件的或者软件的防火墙两种.无论是在哪个网络中,防火墙工作的地方一定是在网络的边缘.而我们的任务就是需要去定义到底 ...

  2. [转帖]总结:Tomcat的IO模型

    一.介绍 对于 linux 操作系统,IO 多路复用使用的是 epoll 方式,对于 windows 操作系统中 IO 多路复用使用的是 iocp 方式,对于 mac 操作系统 IO 多路复用使用的是 ...

  3. 使用Configmap 配置 springboot的application.yaml文件的方式部署环境的方法

    Configmap部署k8s下Springboot服务的办法 前提 日常工作中需要使用k8s部署微服务环境, 但是内部的数据库连接和redis等连接非常麻烦,使用helm chart 进行变量替换时非 ...

  4. 详解Promise.race()可以解决多个异步请求那个请求先返回

    Promise.race([]);接受一个参数,由promise组成的一个数组: 它的返回结果是promise对象: 它的结果和状态由什么去决定呢? 由第一个改变Promise状态的对象去决定:若是返 ...

  5. true=='true'这个等式成立吗?

    在localStorage存入里面的数据是字符串,如果你存入了一个值是Boolean类型的, 那你你取出来就是一个字符串 'true' 或者 'false' 假设取出来的值是 'true' 在你进行i ...

  6. 【1】windows下安装OpenCV(4.3)+VS2017安装+opencv_contrib4.3.0配置

    相关文章: [1]windows下安装OpenCV(4.3)+VS2017安装+opencv_contrib4.3.0配置 [2]Visual Studio 2017同时配置OpenCV2.4 以及O ...

  7. Linux的用户和权限 [补档-2023-07-07]

    Linux用户和权限 3-1. su用户切换命令 exit用户退出命令 ​ 用户切换命令的语法: ​ su [-] [用户名] ​ 其中: ​ - 可选,表示是否在切换用户后加载环境变量,建议带上. ...

  8. 突破SESSION 0隔离的远程线程注入

    与传统的 CreateRemoteThread 函数实现的远线程注入 DLL 的唯一区别在于,突破 SESSION 0 远线程注 入技术是使用比 CreateRemoteThread 函数更为底层的 ...

  9. FDMemTable用法

    procedure TForm1.FormCreate(Sender: TObject); Var i:integer; begin // i:=15; self.FDMemTable1.FieldD ...

  10. 开源.NetCore通用工具库Xmtool使用连载 - 发送短信篇

    [Github源码] <上一篇> 介绍了Xmtool工具库中的发送邮件类库,今天我们继续为大家介绍其中的发送短信类库. 发送短信就像发送邮件一样,在软件系统中使用非常普遍,甚至比发送邮件还 ...