之前发现了一个习题网站codewars,与leetcode类似,但又有点区别,leetcode完全是算法相关,但是这个网站的习题大部分考的是对js内置函数的使用,用来巩固js的知识,我觉得挺好的。
这个网站是外国的,完全是英文,需要网页翻译插件来辅助。
每天学习累了之后可以写一些题换换脑子,遇到不会的可以直接查看答案,但是查看答案后就无法获得这道题的分数。
Persistent Bugger
> 编写一个函数,persistence,它接受一个正参数num并返回它的乘法持久性,
> 它是您必须将数字相乘num直到达到一位数的次数。
> 案例:
persistence(39) === 3 // because 3*9 = 27, 2*7 = 14, 1*4=4
// and 4 has only one digit
persistence(999) === 4 // because 9*9*9 = 729, 7*2*9 = 126,
// 1*2*6 = 12, and finally 1*2 = 2
persistence(4) === 0 // because 4 is already a one-digit number
>解决方案
function persistence(num) {
//code me
let i;
for (i = 0; num > 9; i++) {
num = num
.toString()
.split('')
.reduce((s, d) => s * d);
}
return i;
}
> 这个题当时没写出来,自己写的自己测试通过,
> 但是在平台运行不通过,就看了一下答案,发现一个简单的写法。
我的字谜在哪里?
> 如果两个单词都包含相同的字母,那么它们就是彼此的字谜。例如:
'abba' & 'baab' == true
'abba' & 'bbaa' == true
'abba' & 'abbba' == false
'abba' & 'abca' == false
> 编写一个函数,从列表中找出一个单词的所有字谜。
> 您将获得两个输入一个单词和一个包含单词的数组。
> 您应该返回一个包含所有字谜> 的数组,如果没有,
> 则返回一个空数组。例如:
>
anagrams('abba', ['aabb', 'abcd', 'bbaa', 'dada']) =>
['aabb', 'bbaa']
anagrams('racer', ['crazer', 'carer', 'racar', 'caers', 'racer'])
=> ['carer', 'racer']
anagrams('laser', ['lazing', 'lazy', 'lacer']) => []
这里用到sort排序可以去看下阮一峰的es6教程es6 sort方法排序里边,有关于最新sort方法的解释。
function anagrams(word, words) {
const arr = [];
// 将要比较的单词先进行排序,以便于后边的比较
word = word.split('').sort().toString();
for (let i = 0; i < words.length; i++) {
// 将数组内的单词排序,排序后和要找的单词进行比较,
// 找到后就将其放入要返回的数组中
if (words[i].split('').sort().toString() == word)
arr.push(words[i]);
}
return arr;
}
下边这个是从题库里边找到的简洁答案
let anagrams = (word, words) =>
words.filter(w => w.split('').sort().join('')
===
word.split('').sort().join(''));