聊聊跟三哥三姐面试和共事的经历

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 2320|回复: 7
收起左侧

Zenefits skype电面

[复制链接] |试试Instant~ |关注本帖
yuanhsh 发表于 2015-4-30 09:32:25 | 显示全部楼层 |阅读模式

2015(4-6月) 码农类General 硕士 全职@Zenefits - 网上海投 - 技术电面  | Fail | fresh grad应届毕业生

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

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

x
// String input (M). visit 1point3acres for more.
// String pattern (N). 牛人云集,一亩三分地

// # output me the number of substrings in input that is an anagram of pattern

// input:abcba
// pattern:abc
// ~> 2

写出了O(MN)的方法,但是他期望O(M)的。用sliding window方法来做,但是我没做出来。思路和leetcode的minmum window substring相似。

评分

1

查看全部评分

本帖被以下淘专辑推荐:

mcry 发表于 2015-4-30 10:39:27 | 显示全部楼层
只是求种类数吗?substring一定是连续的吗?.本文原创自1point3acres论坛
如果是的话,比minmum window substring简单些,pattern大小是一定的相当于window size是一定的,用一个定长的queue,遍历input,进一位,pop一个,同时更新hashmap

补充内容 (2015-4-30 10:43):
不需要真的queue,就位置减去pattern长度定位就好
回复 支持 反对

使用道具 举报

biubiu 发表于 2015-4-30 11:09:32 | 显示全部楼层
public static int countStr(String s, String p){
                if( s == null || p == null || p.length() > s.length()){
                        return 0;. 留学申请论坛-一亩三分地
                }. 1point 3acres 论坛
                HashMap<Character,Integer> dict = new HashMap<Character,Integer>();. From 1point 3acres bbs
                for(int i = 0; i < p.length(); i++){
                        if(dict.containsKey(p.charAt(i))){
                                dict.put(p.charAt(i), dict.get(p.charAt(i))+1);
                        }else{
                                dict.put(p.charAt(i), 1);
                        }
                }. 1point 3acres 论坛
                int num = 0;
                int left = 0;
                int count = 0;
                for(int right = 0; right < s.length(); right++){
                        if(dict.containsKey(s.charAt(right))){
                                dict.put(s.charAt(right),dict.get(s.charAt(right))-1);
                                if(dict.get(s.charAt(right)) >= 0){
. 围观我们@1point 3 acres                                        count++;
                                }. 一亩-三分-地,独家发布
                                while(count == p.length()){
                                        if((right - left + 1) == p.length()){. visit 1point3acres for more.
                                                num++;
                                        }. from: 1point3acres
                                        if(dict.containsKey(s.charAt(left))){.留学论坛-一亩-三分地
                                                dict.put(s.charAt(left), dict.get(s.charAt(left))+1);
                                                if(dict.get(s.charAt(left)) > 0){
                                                        count--;
                                                }
                                        }
                                        left++;. 留学申请论坛-一亩三分地
                                }
                        }
                }
                return num;
        }

zheng yang ke bu ke yi
mei you shu ru fa hao tou teng
回复 支持 反对

使用道具 举报

EchoO 发表于 2015-5-1 01:31:28 | 显示全部楼层
biubiu 发表于 2015-4-30 11:09
public static int countStr(String s, String p){
                if( s == null || p == null || p.length() > s.leng ...

你的算法是如果S=abcdab, T = abc会返回2还是1?
回复 支持 反对

使用道具 举报

biubiu 发表于 2015-5-3 11:24:44 | 显示全部楼层
EchoO 发表于 2015-5-1 01:31
你的算法是如果S=abcdab, T = abc会返回2还是1?

好像是1?
cdab应该不是abc的anagram?
回复 支持 反对

使用道具 举报

 楼主| yuanhsh 发表于 2015-5-3 22:58:42 | 显示全部楼层
mcry 发表于 2015-4-30 10:39
只是求种类数吗?substring一定是连续的吗?. 围观我们@1point 3 acres
如果是的话,比minmum window substring简单些,pattern大小 ...

是的,substring一定要连续
回复 支持 反对

使用道具 举报

yyboyz 发表于 2016-1-28 06:36:37 | 显示全部楼层
biubiu 发表于 2015-4-30 11:09
public static int countStr(String s, String p){
                if( s == null || p == null || p.length() > s.leng ...

你的算法错了
. 一亩-三分-地,独家发布
我测试countStr("abc","aabac")  返回0  应该是1

补充内容 (2016-1-28 07:00):
我不对 把参数放反了 你的算法对的!
回复 支持 反对

使用道具 举报

池大侠 发表于 2016-2-24 03:37:46 | 显示全部楼层
写了两种方法 第一种naive 第二种O(m)
  1. def findanagram(string, pattern):
  2.         string_len = len(string)
  3.         pattern_len = len(pattern)
  4.         if string_len < pattern_len:
  5.                 return 0. 牛人云集,一亩三分地
  6.         anagram = set().留学论坛-一亩-三分地
  7.         window_len = len(pattern)
  8.         for i in range(string_len - pattern_len + 1):. 围观我们@1point 3 acres
  9.                 #print string[i:i+pattern_len]
  10.                 cur_string = string[i : i + pattern_len].本文原创自1point3acres论坛
  11.                 if sorted(cur_string) == sorted(pattern) and cur_string != pattern:
  12.                         anagram.add(cur_string)
  13.         print anagram
  14.         return len(anagram)
  15. . 1point 3acres 论坛
  16. print findanagram('aabacabc', 'abc')
  17. . Waral 博客有更多文章,

  18. def findanagramFast(string, pattern):
  19.         string_len = len(string)
  20.         pattern_len = count = len(pattern)
  21.         if string_len < pattern_len:
  22.                 return 0
  23.         anagram = set()
  24.         window_len = len(pattern)
  25.         pattern_hash = {}
  26.         start = 0
  27.         for char in pattern:
  28.                 pattern_hash[char] = pattern_hash.get(char, 0) + 1. visit 1point3acres for more.
  29.                 pattern_hash2[char] = pattern_hash2.get(char, 0) + 1. 一亩-三分-地,独家发布
  30.         for index, char in string:
  31.                 if pattern_hash.get(char, 0):
  32.                         pattern_hash2[char] -= 1
  33.                         if pattern_hash[char] >= 0:
  34.                                 count -= 1.本文原创自1point3acres论坛
  35.                 if count == 0:
  36.                         while True:
  37.                                 if pattern_hash.get(char, 0):
  38.                                         if pattern_hash2[char] < 0:
  39.                                                 pattern_hash2[char] += 1
  40.                                         else:
  41.                                                 break. from: 1point3acres
  42.                                 start += 1
  43.                         if index - start + 1 == pattern_len and string[start : start + pattern_len] != pattern:
  44.                                 anagram.add(string[start : start + pattern_len])
  45.         return anagram.1point3acres网

  46. print findanagram('aabacabc', 'abc')
复制代码
Mobile Apps Category (English)728x90
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2018-5-22 16:38

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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