近期论坛无法登录的解决方案


一亩三分地论坛

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

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

Zenefits skype电面

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

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

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

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

x
// String input (M)
. 1point 3acres 璁哄潧// String pattern (N)
.1point3acres缃
// # output me the number of substrings in input that is an anagram of pattern. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴

// input:abcba. from: 1point3acres.com/bbs
// pattern:abc
// ~> 2-google 1point3acres

写出了O(MN)的方法,但是他期望O(M)的。用sliding window方法来做,但是我没做出来。思路和leetcode的minmum window substring相似。
. 鍥磋鎴戜滑@1point 3 acres

评分

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):
不需要真的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;
                }
                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);
                        }. from: 1point3acres.com/bbs
                }
                int num = 0; 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
                int left = 0;
                int count = 0;
                for(int right = 0; right < s.length(); right++){. 1point 3acres 璁哄潧
                        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))){
                                                dict.put(s.charAt(left), dict.get(s.charAt(left))+1);
                                                if(dict.get(s.charAt(left)) > 0){
                                                        count--;
                                                }
                                        }
                                        left++;
                                }
                        }
                }
                return num;
        }
. 鍥磋鎴戜滑@1point 3 acres
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. 鍥磋鎴戜滑@1point 3 acres
你的算法是如果S=abcdab, T = abc会返回2还是1?
.鏈枃鍘熷垱鑷1point3acres璁哄潧
好像是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)
  3.         pattern_len = len(pattern)
  4.         if string_len < pattern_len:. more info on 1point3acres.com
  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]
  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. . 1point 3acres 璁哄潧
  16. print findanagram('aabacabc', 'abc')


  17. def findanagramFast(string, pattern):
  18.         string_len = len(string)
  19.         pattern_len = count = len(pattern)
  20.         if string_len < pattern_len:
  21.                 return 0
  22.         anagram = set()
  23.         window_len = len(pattern). more info on 1point3acres.com
  24.         pattern_hash = {}
  25.         start = 0
  26.         for char in pattern:
  27.                 pattern_hash[char] = pattern_hash.get(char, 0) + 1
  28.                 pattern_hash2[char] = pattern_hash2.get(char, 0) + 1
  29.         for index, char in string:.鐣欏璁哄潧-涓浜-涓夊垎鍦
  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:.鏈枃鍘熷垱鑷1point3acres璁哄潧
  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

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

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-6-28 14:12

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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