推荐:数据科学课程和书籍清单以及培训讲座


一亩三分地论坛

 找回密码
 获取更多干活,快来注册

一亩三分地官方iOS手机应用下载
查看: 2150|回复: 7
收起左侧

Zenefits skype电面

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

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

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

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

x
// String input (M)
// String pattern (N). 1point3acres.com/bbs

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

// input:abcba
// pattern:abc
// ~> 2.鏈枃鍘熷垱鑷1point3acres璁哄潧
. From 1point 3acres bbs
写出了O(MN)的方法,但是他期望O(M)的。用sliding window方法来做,但是我没做出来。思路和leetcode的minmum window substring相似。

评分

1

查看全部评分

本帖被以下淘专辑推荐:

mcry 发表于 2015-4-30 10:39:27 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
只是求种类数吗?substring一定是连续的吗?
如果是的话,比minmum window substring简单些,pattern大小是一定的相当于window size是一定的,用一个定长的queue,遍历input,进一位,pop一个,同时更新hashmap

补充内容 (2015-4-30 10:43):. 鍥磋鎴戜滑@1point 3 acres
不需要真的queue,就位置减去pattern长度定位就好
回复 支持 反对

使用道具 举报

biubiu 发表于 2015-4-30 11:09:32 | 显示全部楼层
关注一亩三分地微博:
Warald
public static int countStr(String s, String p){
. from: 1point3acres.com/bbs                 if( s == null || p == null || p.length() > s.length()){
                        return 0;-google 1point3acres
                }
                HashMap<Character,Integer> dict = new HashMap<Character,Integer>();.鐣欏璁哄潧-涓浜-涓夊垎鍦
                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);
                        }. visit 1point3acres.com for more.
                }
                int num = 0;. 1point3acres.com/bbs
                int left = 0;
                int count = 0;. 1point 3acres 璁哄潧
                for(int right = 0; right < s.length(); right++){. Waral 鍗氬鏈夋洿澶氭枃绔,
                        if(dict.containsKey(s.charAt(right))){. 1point 3acres 璁哄潧
                                dict.put(s.charAt(right),dict.get(s.charAt(right))-1);.1point3acres缃
                                if(dict.get(s.charAt(right)) >= 0){
                                        count++;
                                }
                                while(count == p.length()){.鐣欏璁哄潧-涓浜-涓夊垎鍦
                                        if((right - left + 1) == p.length()){. more info on 1point3acres.com
                                                num++;
                                        }. Waral 鍗氬鏈夋洿澶氭枃绔,
                                        if(dict.containsKey(s.charAt(left))){
                                                dict.put(s.charAt(left), dict.get(s.charAt(left))+1);
                                                if(dict.get(s.charAt(left)) > 0){. 鍥磋鎴戜滑@1point 3 acres
                                                        count--;. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
                                                }.1point3acres缃
                                        }
                                        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 ...
. from: 1point3acres.com/bbs
你的算法是如果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一定是连续的吗?-google 1point3acres
如果是的话,比minmum window substring简单些,pattern大小 ...
. more info on 1point3acres.com
是的,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):.1point3acres缃
我不对 把参数放反了 你的算法对的!
回复 支持 反对

使用道具 举报

池大侠 发表于 2016-2-24 03:37:46 | 显示全部楼层
写了两种方法 第一种naive 第二种O(m)
  1. def findanagram(string, pattern):
  2.         string_len = len(string). from: 1point3acres.com/bbs
  3.         pattern_len = len(pattern)
  4.         if string_len < pattern_len:
  5.                 return 0
  6.         anagram = set().鏈枃鍘熷垱鑷1point3acres璁哄潧
  7.         window_len = len(pattern)
    . visit 1point3acres.com for more.
  8.         for i in range(string_len - pattern_len + 1):
  9.                 #print string[i:i+pattern_len]. more info on 1point3acres.com
  10.                 cur_string = string[i : i + pattern_len]. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  11.                 if sorted(cur_string) == sorted(pattern) and cur_string != pattern:.鏈枃鍘熷垱鑷1point3acres璁哄潧
  12.                         anagram.add(cur_string)
  13.         print anagram .1point3acres缃
  14.         return len(anagram)

  15. print findanagram('aabacabc', 'abc')


  16. def findanagramFast(string, pattern):
  17.         string_len = len(string)
  18.         pattern_len = count = len(pattern) 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  19.         if string_len < pattern_len:
  20.                 return 0
  21.         anagram = set()
  22.         window_len = len(pattern)-google 1point3acres
  23.         pattern_hash = {}
  24.         start = 0
  25.         for char in pattern:
  26.                 pattern_hash[char] = pattern_hash.get(char, 0) + 1.鐣欏璁哄潧-涓浜-涓夊垎鍦
  27.                 pattern_hash2[char] = pattern_hash2.get(char, 0) + 1. Waral 鍗氬鏈夋洿澶氭枃绔,
  28.         for index, char in string:
  29.                 if pattern_hash.get(char, 0):.鐣欏璁哄潧-涓浜-涓夊垎鍦
  30.                         pattern_hash2[char] -= 1
  31.                         if pattern_hash[char] >= 0:
  32.                                 count -= 1
  33.                 if count == 0:
  34.                         while True:. 1point 3acres 璁哄潧
  35.                                 if pattern_hash.get(char, 0):
  36.                                         if pattern_hash2[char] < 0:
  37.                                                 pattern_hash2[char] += 1
  38.                                         else:
  39.                                                 break
  40.                                 start += 1.鏈枃鍘熷垱鑷1point3acres璁哄潧
  41.                         if index - start + 1 == pattern_len and string[start : start + pattern_len] != pattern:
  42.                                 anagram.add(string[start : start + pattern_len])
  43.         return anagram

  44. print findanagram('aabacabc', 'abc')
复制代码
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-7-26 06:45

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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