请问如果快速找到相同值的子序列的位置?有什么好办法没有呢?

2015-11-01 11:10:45 +08:00
 meteor2013
比如:
11111111000001111101111100000001111

返回 7 个子序列,和他们的位置
1, (1,8)
2, (9,13 )
3, (14,18)
4, (19,19)
5, (20,24)
6, (25,31)
7, (32,35)
1810 次点击
所在节点    程序员
6 条回复
llbbzh
2015-11-01 11:53:03 +08:00
滑动窗口啊。
设序列为 a ,指定两个指针 h ( head ), t ( tail ),规定区间[h,t]中的数字必须全部为某个值,设为 v
为了让[h,t]中的数字全为 v ,显然初始时 h==t==1
如果 a[t+1]==v ,那么 t++
如果 a[t+1]!=v ,那么输出 h 和 t ,并令 v=a[t+1],h=t=t+1
时间复杂度 O(n)
Magic347
2015-11-01 12:05:34 +08:00
def find(s):
ret = []
if s is None or len(s) == 0:
return ret
start = 0
curr = s[0]
for i in range(0, len(s)):
if s[i] != curr:
ret.append((start+1, i))
start = i
curr = s[i]
if i == len(s) - 1:
ret.append((start+1, len(s)))
else:
if i == len(s) - 1:
ret.append((start+1, len(s)))
return ret


算法上没有特别之处,只是处理一些边界 case 时要细致一些,提供一些测试用例

find("")


find("10")
(1, 1)
(2, 2)

find("1111")
(1, 4)

find("1")
(1, 1)

find("11111111000001111101111100000001111")
(1, 8)
(9, 13)
(14, 18)
(19, 19)
(20, 24)
(25, 31)
(32, 35)
Magic347
2015-11-01 12:21:38 +08:00
这个回帖过滤代码缩进真是闹心啊,站主是不是可以考虑加一个代码缩进和高亮啊?

def find(s):
____ret = []
____if s is None or len(s) == 0:
________return ret
____start = 0
____curr = s[0]
____for i in range(0, len(s)):
________if s[i] != curr:
____________ret.append((start+1, i))
____________start = i
____________curr = s[i]
____________if i == len(s) - 1:
________________ret.append((start+1, len(s)))
________else:
____________if i == len(s) - 1:
________________ret.append((start+1, len(s)))
____return ret
meteor2013
2015-11-01 12:29:47 +08:00
@Magic347 谢谢哥们啊,太贴心了
话说代码缩进和高亮真的很有需要
Slienc7
2015-11-01 13:56:10 +08:00
menc
2015-11-02 01:09:36 +08:00
https://gist.github.com/PengFoo/51c0428fb67447abaf6a


print find("10")
print find("1111")
print find("1")
print find("11111111000001111101111100000001111")
结果分别为:
[(1, 1), (2, 2)]
[(1, 4)]
[(1, 1)]
[(1, 8), (9, 13), (14, 18), (19, 19), (20, 24), (25, 31), (32, 35)]

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/232643

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX