Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
GreyZeng
algorithm
提交
10e69b5f
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,发现更多精彩内容 >>
提交
10e69b5f
编写于
1月 10, 2024
作者:
GreyZeng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
merge sort ref
上级
6384301d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
22 deletion
+15
-22
src/main/java/git/snippet/mergesort/LeetCode_0327_CountOfRangeSum.java
.../git/snippet/mergesort/LeetCode_0327_CountOfRangeSum.java
+15
-22
未找到文件。
src/main/java/git/snippet/mergesort/LeetCode_0327_CountOfRangeSum.java
浏览文件 @
10e69b5f
...
...
@@ -2,6 +2,8 @@ package git.snippet.mergesort;
import
java.util.HashSet
;
// TODO
// 需要多练习的题目
// https://leetcode.com/problems/count-of-range-sum/
// 方法1:归并排序
// 笔记:https://www.cnblogs.com/greyzeng/p/16653063.html
...
...
@@ -20,16 +22,20 @@ import java.util.HashSet;
// 有序表提供add(num) [可以加入重复数字] 和 search(L,R)【L...R中有多少个,其实只需要提供<num的数有多少个这个接口加工而来】 两个接口即可
// 左滑不处理,右滑累加,每个数据项里面包含节点个数
public
class
LeetCode_0327_CountOfRangeSum
{
public
int
countRangeSum
(
int
[]
nums
,
int
lower
,
int
upper
)
{
if
(
null
==
nums
||
nums
.
length
<
1
)
{
return
0
;
}
long
[]
preSum
=
new
long
[
nums
.
length
];
preSum
[
0
]
=
nums
[
0
];
for
(
int
i
=
1
;
i
<
nums
.
length
;
i
++)
{
preSum
[
i
]
=
preSum
[
i
-
1
]
+
nums
[
i
];
}
return
count
(
preSum
,
0
,
preSum
.
length
-
1
,
lower
,
upper
);
return
process
(
preSum
,
0
,
nums
.
length
-
1
,
lower
,
upper
);
}
public
int
count
(
long
[]
preSum
,
int
l
,
int
r
,
int
lower
,
int
upper
)
{
public
int
process
(
long
[]
preSum
,
int
l
,
int
r
,
int
lower
,
int
upper
)
{
if
(
l
==
r
)
{
if
(
preSum
[
l
]
<=
upper
&&
preSum
[
l
]
>=
lower
)
{
return
1
;
...
...
@@ -37,18 +43,13 @@ public class LeetCode_0327_CountOfRangeSum {
return
0
;
}
int
m
=
l
+
((
r
-
l
)
>>
1
);
int
left
=
count
(
preSum
,
l
,
m
,
lower
,
upper
);
int
right
=
count
(
preSum
,
m
+
1
,
r
,
lower
,
upper
);
int
merge
=
merge
(
preSum
,
l
,
m
,
r
,
lower
,
upper
);
return
left
+
right
+
merge
;
return
process
(
preSum
,
l
,
m
,
lower
,
upper
)
+
process
(
preSum
,
m
+
1
,
r
,
lower
,
upper
)
+
merge
(
preSum
,
l
,
m
,
r
,
lower
,
upper
);
}
private
int
merge
(
long
[]
preSum
,
int
l
,
int
m
,
int
r
,
int
lower
,
int
upper
)
{
int
ans
=
0
;
// 单调性->滑动窗口
public
int
merge
(
long
[]
preSum
,
int
l
,
int
m
,
int
r
,
int
lower
,
int
upper
)
{
int
windowL
=
l
;
int
windowR
=
l
;
// [windowL, windowR)
int
ans
=
0
;
for
(
int
i
=
m
+
1
;
i
<=
r
;
i
++)
{
long
min
=
preSum
[
i
]
-
upper
;
long
max
=
preSum
[
i
]
-
lower
;
...
...
@@ -58,20 +59,14 @@ public class LeetCode_0327_CountOfRangeSum {
while
(
windowL
<=
m
&&
preSum
[
windowL
]
<
min
)
{
windowL
++;
}
ans
+=
windowR
-
windowL
;
ans
+=
(
windowR
-
windowL
)
;
}
// mergeSort经典代码
long
[]
helper
=
new
long
[
r
-
l
+
1
];
int
ls
=
l
;
int
rs
=
m
+
1
;
int
index
=
0
;
while
(
ls
<=
m
&&
rs
<=
r
)
{
if
(
preSum
[
ls
]
>
preSum
[
rs
])
{
helper
[
index
++]
=
preSum
[
rs
++];
}
else
{
helper
[
index
++]
=
preSum
[
ls
++];
}
helper
[
index
++]
=
preSum
[
ls
]
<
preSum
[
rs
]
?
preSum
[
ls
++]
:
preSum
[
rs
++];
}
while
(
ls
<=
m
)
{
helper
[
index
++]
=
preSum
[
ls
++];
...
...
@@ -79,13 +74,11 @@ public class LeetCode_0327_CountOfRangeSum {
while
(
rs
<=
r
)
{
helper
[
index
++]
=
preSum
[
rs
++];
}
int
k
=
0
;
for
(
long
num
:
helper
)
{
preSum
[
l
+
(
k
++)]
=
num
;
}
System
.
arraycopy
(
helper
,
0
,
preSum
,
l
,
helper
.
length
);
return
ans
;
}
// ways2 通过改有序表的方式实现。
public
int
countRangeSum2
(
int
[]
nums
,
int
lower
,
int
upper
)
{
// 黑盒,加入数字(前缀和),不去重,可以接受重复数字
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录