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


一亩三分地论坛

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

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

Hulu

[复制链接] |试试Instant~ |关注本帖
106 发表于 2015-5-23 11:57:26 | 显示全部楼层 |阅读模式

2015(1-3月) 码农类 硕士 全职@Hulu - 内推 - 技术电面 |Passfresh grad应届毕业生

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

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

x
Hulu电面
随便问一下我的实习经历, 讲了一分钟就直接coding了。 isAngram 两种方法及其变体。
// Ransom Note
// magazine = "cdhjkscjgcdjkshvfhjgdu..." "themet"
// note = "Meet me somewhere" "meet" a-z A-Z 0-9. 鍥磋鎴戜滑@1point 3 acres
.鏈枃鍘熷垱鑷1point3acres璁哄潧
boolean canMakeRansomNote(String magazine, String note) {
//assume the input is not null
Map<Character, Frequence> map = new HashMap<>();
for(int i = 0; i < note.length(); i++){
char c = note.charAt(i);
if(isValid(c)) //ignore any space or illegal chars{. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
int freq = map.containsKey(c) ? map.get(c)+1 : 1;
map.put(c, freq);
}
}

for(int i = 0; i < magazine.length(); i++){
char c = magazine.charAt(i);. Waral 鍗氬鏈夋洿澶氭枃绔,
if(isValid(c) && map.containsKey(c){ //care about the chars occured in notes.. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
int newFreq = map.get(c)-1; //found a char which is contained in notes
if(newFreq <= 0){
map.remove(c);
if(map.isEmpty())
return true;. more info on 1point3acres.com
}
else
map.put(c, newFreq);

.鏈枃鍘熷垱鑷1point3acres璁哄潧
}

return false;. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
}
}

public boolean isValid(char c){ //c is Uni-8, int = 65 ('A')
if(c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z' || c >= '0' && c <= '9')
return true;
return false;. 1point3acres.com/bbs
}. visit 1point3acres.com for more.

// "abc", "cab" -> true "[a, b , c] [a, b, c]
// "abc", "def" -> false


void isAnagram(String string1, String string2) {. 鍥磋鎴戜滑@1point 3 acres
//first idea: sort them and then compare if it is equals
//assume input is not null
if(string1.length() != string2.length()). 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
return false;

Map<Character, Integer> map = new HashMap<>();
//iterate string1 and store it in map
for(int i = 0; i < string1.length(); i++){
char c = string1.charAt(i);
int freq = map.containsKey(c) ? map.get(c)+1 : 1;
map.put(c, freq);. 1point 3acres 璁哄潧
}

//iterate the other string to check
for(int i = 0; i < string2.length(); i++){
char c = string2.charAt(i);
if(!map.containsKey(c))
return false;
//decrease freq
int newFreq = map.get(c)-1;. From 1point 3acres bbs
if(newFreq < 0)-google 1point3acres
return false;

map.put(c, newFreq);
}

return true;. From 1point 3acres bbs
}. more info on 1point3acres.com




void isAnagram(String string1, String string2) {
//first idea: sort them and then compare if it is equals. 1point 3acres 璁哄潧
//assume input is not null
if(string1.length() != string2.length()).鏈枃鍘熷垱鑷1point3acres璁哄潧
return false;

char[] S1 = string1.toCharArray();. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
char[] S2 = string2.toCharArray()

Arrays.sort(S1);
Arrays.sort(s2);

return isEqual(S1, S2); // Arrays.toStint(s1).equals(Arrays.toString(S2));
}
. Waral 鍗氬鏈夋洿澶氭枃绔,
public boolean isEqual(char[] A, char[] B){
//cornet case
if(A == null && B == null)
return true;. From 1point 3acres bbs

//only one of them is null
if(A == null || B == null)
returnf false;

for(int i = 0; i < A.length; i++){
if(A != B)
return false;. from: 1point3acres.com/bbs
}

return true;
}


评分

1

查看全部评分

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-8-16 23:32

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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