要回国了,写个简单的总结吧。

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投
内推多家公司面试
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
把贵司招聘信息放这里
查看: 788|回复: 1
收起左侧

[Leetcode] 求问LC392判断是否子序列的题

[复制链接] |试试Instant~ |关注本帖
我的人缘0
南方Giraffe 发表于 2016-9-22 22:08:56 | 显示全部楼层 |阅读模式
  此人很可信:
 
0% (暂未有人投票) 【我投】
  此人瞎逼逼:
 
0% (暂未有人投票) 【我投】

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
LC392https://leetcode.com/problems/is-subsequence/


1. s和t都是String,判断s是否t的子序列(不必连续),其中s较小(<100),t较大(~=500000)
2. 如果有很多s ( s的个数大于1B),要一个个判断是否t的子序列,如何改进?

对于问题1,我用的是two pointer的方法,时间复杂度是O(t.length)。求问有没有更好的方法?
问题2完全没有头绪,求问各位有没有什么想法?

感谢

上一篇:Snapchat BloomFilter Remove
下一篇:求刷题小组
我的人缘0
Tsien 发表于 2016-9-22 23:19:42 | 显示全部楼层
  此人很可信:
 
0% (暂未有人投票) 【我投】
  此人瞎逼逼:
 
0% (暂未有人投票) 【我投】
用hashmap保存t,key是字母,value是个vector保存该字母在t中出现时的index,增序,记作map1
用另一个hashmap计数s,key是字母,value是该字母的occurence, 记作map2
对s中的每个字母,利用当前的occurence先去map1里找index,然后跟之前一个字母的index比较大小
time O(s.length), space O(t.length)
回复 支持 反对

使用道具 举报

全球28万学生4.7分推荐
游客
请先登录

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-28 00:07

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表