一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 1395|回复: 7
收起左侧

Zenefits skype电面

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

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

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

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

x
// String input (M)
// String pattern (N)

// # output me the number of substrings in input that is an anagram of pattern. from: 1point3acres.com/bbs

// input:abcba
// pattern:abc
// ~> 2. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴

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

评分

1

查看全部评分

本帖被以下淘专辑推荐:

mcry 发表于 2015-4-30 10:39:27 | 显示全部楼层
只是求种类数吗?substring一定是连续的吗?
如果是的话,比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()){. Waral 鍗氬鏈夋洿澶氭枃绔,
                        return 0;
                }
                HashMap<Character,Integer> dict = new HashMap<Character,Integer>();. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
                for(int i = 0; i < p.length(); i++){.鏈枃鍘熷垱鑷1point3acres璁哄潧
                        if(dict.containsKey(p.charAt(i))){
                                dict.put(p.charAt(i), dict.get(p.charAt(i))+1);
                        }else{
                                dict.put(p.charAt(i), 1);
                        } 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
                }
                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){
                                        count++;
                                }
                                while(count == p.length()){
                                        if((right - left + 1) == p.length()){
                                                num++;
                                        }
                                        if(dict.containsKey(s.charAt(left))){. 鍥磋鎴戜滑@1point 3 acres
                                                dict.put(s.charAt(left), dict.get(s.charAt(left))+1);. 1point 3acres 璁哄潧
                                                if(dict.get(s.charAt(left)) > 0){
                                                        count--;
                                                }
                                        }
                                        left++;.鐣欏璁哄潧-涓浜-涓夊垎鍦
                                }. visit 1point3acres.com for more.
                        }
                }
                return num;
        }

-google 1point3acreszheng 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一定是连续的吗?
如果是的话,比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
. From 1point 3acres bbs
补充内容 (2016-1-28 07:00):
我不对 把参数放反了 你的算法对的!
回复 支持 反对

使用道具 举报

池大侠 发表于 2016-2-24 03:37:46 | 显示全部楼层
写了两种方法 第一种naive 第二种O(m)
  1. def findanagram(string, pattern):
  2.         string_len = len(string).鏈枃鍘熷垱鑷1point3acres璁哄潧
  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):
  9.                 #print string[i:i+pattern_len]. 鍥磋鎴戜滑@1point 3 acres
  10.                 cur_string = string[i : i + pattern_len]
  11.                 if sorted(cur_string) == sorted(pattern) and cur_string != pattern:
  12.                         anagram.add(cur_string)
  13.         print anagram
  14.         return len(anagram)
  15. .鏈枃鍘熷垱鑷1point3acres璁哄潧
  16. print findanagram('aabacabc', 'abc')


  17. def findanagramFast(string, pattern):
    . 1point3acres.com/bbs
  18.         string_len = len(string). Waral 鍗氬鏈夋洿澶氭枃绔,
  19.         pattern_len = count = len(pattern)
  20.         if string_len < pattern_len:
  21.                 return 0
  22.         anagram = set()
  23.         window_len = len(pattern)
  24.         pattern_hash = {}
  25.         start = 0
  26.         for char in pattern:. 1point 3acres 璁哄潧
  27.                 pattern_hash[char] = pattern_hash.get(char, 0) + 1
  28.                 pattern_hash2[char] = pattern_hash2.get(char, 0) + 1
    . 鍥磋鎴戜滑@1point 3 acres
  29.         for index, char in string:.1point3acres缃
  30.                 if pattern_hash.get(char, 0):
  31.                         pattern_hash2[char] -= 1
  32.                         if pattern_hash[char] >= 0:
  33.                                 count -= 1
  34.                 if count == 0:
  35.                         while True:
  36.                                 if pattern_hash.get(char, 0):
  37.                                         if pattern_hash2[char] < 0:
  38.                                                 pattern_hash2[char] += 1
  39.                                         else:
  40.                                                 break
  41.                                 start += 1
  42.                         if index - start + 1 == pattern_len and string[start : start + pattern_len] != pattern:
  43.                                 anagram.add(string[start : start + pattern_len])
  44.         return anagram. Waral 鍗氬鏈夋洿澶氭枃绔,

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

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

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

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-7 02:13

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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