Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
GreyZeng
algorithm
提交
381dc676
A
algorithm
项目概览
GreyZeng
/
algorithm
通知
10
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
algorithm
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
381dc676
编写于
12月 06, 2022
作者:
GreyZeng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
cover max problem
上级
4a1a5cef
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
52 addition
and
27 deletion
+52
-27
src/main/java/nowcoder/NowCoder_LineCoverMax.java
src/main/java/nowcoder/NowCoder_LineCoverMax.java
+52
-27
未找到文件。
src/main/java/nowcoder/NowCoder_LineCoverMax.java
浏览文件 @
381dc676
...
...
@@ -6,6 +6,9 @@ import java.util.HashMap;
import
java.util.PriorityQueue
;
import
java.util.Scanner
;
import
java.util.TreeSet
;
import
java.util.function.Predicate
;
import
java.util.stream.Stream
;
// 线段的最大重合问题
// https://www.nowcoder.com/questionTerminal/f8fa4b67dd054892966d280790c42ba3
// 连接点算重合部分
...
...
@@ -14,6 +17,55 @@ import java.util.TreeSet;
// https://www.cnblogs.com/greyzeng/p/15058662.html
// 线段树解法
public
class
NowCoder_LineCoverMax
{
// 暴力解
// 1. 首先得到线段的最大值和最小值
// 2. 最大值和最小值按单位1等分,看每条线覆盖了多少,抓一下全局max
// 复杂度O(n*(max-min))
public
static
int
maxCover3
(
int
[][]
lines
)
{
int
min
=
lines
[
0
][
0
];
int
max
=
lines
[
0
][
1
];
for
(
int
[]
line
:
lines
)
{
min
=
Math
.
min
(
min
,
line
[
0
]);
max
=
Math
.
max
(
max
,
line
[
1
]);
}
int
cover
=
0
;
int
maxCover
=
0
;
for
(
int
i
=
min
;
i
<=
max
;
i
++)
{
for
(
int
[]
line
:
lines
)
{
// 这里要注意 如果[1,2] ,[2, 3] 中2 算一个重合点的话,
// 则条件为:line[0] <= i && line[1] >= i
// 如果不算的话,line[0] <= i+0.5 && line[1] >= i + 0.5
if
(
line
[
0
]
<=
i
&&
line
[
1
]
>=
i
)
{
cover
++;
}
}
maxCover
=
Math
.
max
(
cover
,
maxCover
);
cover
=
0
;
}
return
maxCover
;
}
// lambda 写法,可过对数器,但是超时,待优化 TODO
// public static int maxCover4(int[][] lines) {
// int min = Arrays.stream(lines).min(Comparator.comparingInt(o -> o[0])).get()[0];
// int max = Arrays.stream(lines).max(Comparator.comparingInt(o -> o[1])).get()[1];
// long cover;
// long maxCover = 0;
// for (int i = min; i <= max; i++) {
// int finalI = i;
// cover =
// Arrays.stream(lines).filter(
// line -> {
// // 这里要注意 如果[1,2] ,[2, 3] 中2 算一个重合点的话,
// // 则条件为:line[0] <= i && line[1] >= i
// // 如果不算的话,line[0] <= i+0.5 && line[1] >= i + 0.5
// return line[0] <= finalI && line[1] >= finalI;
// })
// .count();
// maxCover = Math.max(cover, maxCover);
// }
// return (int)maxCover;
// }
// 堆解法
public
static
int
maxCover
(
int
[][]
m
)
{
...
...
@@ -133,33 +185,6 @@ public class NowCoder_LineCoverMax {
}
}
// 暴力解
// 1. 首先得到线段的最大值和最小值
// 2. 最大值和最小值按单位1等分,看每条线覆盖了多少,抓一下全局max
public
static
int
maxCover3
(
int
[][]
lines
)
{
int
min
=
lines
[
0
][
0
];
int
max
=
lines
[
0
][
1
];
for
(
int
[]
line
:
lines
)
{
min
=
Math
.
min
(
min
,
Math
.
min
(
line
[
0
],
line
[
1
]));
max
=
Math
.
max
(
max
,
Math
.
max
(
line
[
0
],
line
[
1
]));
}
int
cover
=
0
;
int
maxCover
=
0
;
for
(
int
i
=
min
;
i
<=
max
;
i
++)
{
for
(
int
[]
line
:
lines
)
{
// 这里要注意 如果[1,2] ,[2, 3] 中2 算一个重合点的话,
// 则条件为:line[0] <= i && line[1] >= i
// 如果不算的话,line[0] <= i+0.5 && line[1] >= i + 0.5
if
(
line
[
0
]
<=
i
&&
line
[
1
]
>=
i
)
{
cover
++;
}
}
maxCover
=
Math
.
max
(
cover
,
maxCover
);
cover
=
0
;
}
return
maxCover
;
}
public
static
class
Line
{
public
int
start
;
public
int
end
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录