在研究万物算法和数据结构时,我试图在Ruby中做我使用Javascript学习到的东西。两种语言都有它们自己的方式来悬挂变量和处理真假。
该算法在JS中工作正常,但是在Ruby中,当在存在哈希的情况下运行三元数时,我得到了nil:NilClass`的经典undefined method
+'。
我尝试事先做一些条件检查,以确保如果对象不存在,则不会通过任何检查。
这是Javascript解决方案:
function validAnagram(str1, str2){
if (str1.length !== str2.length) {
return false;
}
const strOneObj = {};
const strTwoObj = {};
for (let char of str1) {
strOneObj[char] = strOneObj[char] + 1 || 1;
}
for (let char of str2) {
strTwoObj[char] = strTwoObj[char] + 1 || 1;
}
for (let values in strOneObj) {
if (strOneObj[values] !== strTwoObj[values]) {
return false;
}
return true;
}
}
validAnagram('cinema', 'ice')
这是Ruby版本:
def valid_anagram(str1, str2)
if str1.length != str2.length
false
else
str_one_hash = {}
str_two_hash = {}
str1.split('').each do |char|
if str_one_hash == nil
str_one_hash[char] = 0
else
str_one_hash[char] += 1
end
(str_one_hash.keys & str_one_hash.keys).each do |char, count|
if str_one_hash[char] != str_one_hash[char]
false
end
end
end
true
end
valid_anagram("cinema", "iceman")
简而言之:如何在漂亮的Ruby中使用它?
答案 0 :(得分:2)
一种红宝石的方法
def valid_anagram(str1, str2)
if str1.length != str2.length
false
else
str_one_hash = str1.split('').map{|char| [char, str1.count(char)]}.to_h
str_two_hash = str2.split('').map{|char| [char, str2.count(char)]}.to_h
str_one_hash == str_two_hash
end
end
答案 1 :(得分:1)
您是如此亲密。
if str_one_hash == nil
是元凶。
if str_one_hash[char] == nil
是您要寻找的。
注意:您可以通过调用str_one_hash = Hash.new { 0 }
来将哈希的默认值设置为0-取消nil检查。