Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xindoo
redis
提交
4aa24e62
R
redis
项目概览
xindoo
/
redis
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
4aa24e62
编写于
4月 01, 2020
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
LCS: other fixes to range emission.
上级
2b67b6b8
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
16 deletion
+20
-16
src/t_string.c
src/t_string.c
+20
-16
未找到文件。
src/t_string.c
浏览文件 @
4aa24e62
...
...
@@ -584,12 +584,13 @@ void lcsCommand(client *c) {
i
=
alen
,
j
=
blen
;
while
(
computelcs
&&
i
>
0
&&
j
>
0
)
{
int
emit_range
=
0
;
if
(
a
[
i
-
1
]
==
b
[
j
-
1
])
{
/* If there is a match, store the character and reduce
* the indexes to look for a new match. */
result
[
idx
-
1
]
=
a
[
i
-
1
];
/* Track the current range. */
int
emit_range
=
0
;
if
(
arange_start
==
alen
)
{
arange_start
=
i
-
1
;
arange_end
=
i
-
1
;
...
...
@@ -605,22 +606,9 @@ void lcsCommand(client *c) {
emit_range
=
1
;
}
}
/* Emit the range if we matched with the first byte of
* one of the two strings. We'll exit the loop ASAP. */
if
(
arange_start
==
0
||
brange_start
==
0
)
emit_range
=
1
;
/* Emit the current range if needed. */
if
(
emit_range
)
{
if
(
arraylenptr
)
{
addReplyArrayLen
(
c
,
2
);
addReplyArrayLen
(
c
,
2
);
addReplyLongLong
(
c
,
arange_start
);
addReplyLongLong
(
c
,
arange_end
);
addReplyArrayLen
(
c
,
2
);
addReplyLongLong
(
c
,
brange_start
);
addReplyLongLong
(
c
,
brange_end
);
}
arange_start
=
alen
;
/* Restart at the next match. */
arraylen
++
;
}
idx
--
;
i
--
;
j
--
;
}
else
{
/* Otherwise reduce i and j depending on the largest
...
...
@@ -631,6 +619,22 @@ void lcsCommand(client *c) {
i
--
;
else
j
--
;
if
(
arange_start
!=
alen
)
emit_range
=
1
;
}
/* Emit the current range if needed. */
if
(
emit_range
)
{
if
(
arraylenptr
)
{
addReplyArrayLen
(
c
,
2
);
addReplyArrayLen
(
c
,
2
);
addReplyLongLong
(
c
,
arange_start
);
addReplyLongLong
(
c
,
arange_end
);
addReplyArrayLen
(
c
,
2
);
addReplyLongLong
(
c
,
brange_start
);
addReplyLongLong
(
c
,
brange_end
);
}
arange_start
=
alen
;
/* Restart at the next match. */
arraylen
++
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录