codewar 上做练习的一些感触

废话

在[codewar][1]上做练习,每次都是尽量快速地做完,然后赶着去看排名里面clever分最高的solution,看完每次都要感叹一下人家怎么可以写得这么简洁,甚至有一次我用了一段大约七八行的代码,别人只用了一行就搞定了。下午做了几个练习,依然是这样的感受,拎出来一个记下来鞭策一下自己。

问题

原题长这样:
Vampire Numbers
Our loose definition of Vampire Numbers can be described as follows:

6 * 21 = 126
# 6 and 21 would be valid 'fangs' for a vampire number as the 
# digits 6, 1, and 2 are present in both the product and multiplicands

10 * 11 = 110
# 110 is not a vampire number since there are three 1's in the
# multiplicands, but only two 1's in the product

解决

这是我写的代码:

var vampire_test = function(a, b){
    var mul=(a*b).toString().split('').sort();
    var pro=(a.toString()+b.toString()).split('').sort();
    if(mul.length!==pro.length){
        return false;
    }else{
        for(var i=0;i<mul.length;i++){
            if(mul[i]!=pro[i])
            {
                return false;
            }
        }
        return true;
    }
}

可以看出真的很大一段,虽然实现了功能......

然后,这是clever最高分的solution:

function vampire_test(a, b){
    return sortStr(a + '' + b) == sortStr(a * b + '');
}
function sortStr(v){ return v.split('').sort().join('') }

总结

我对比了一下,发现我的答案里,第一步和别人是类似的:将字符串转成数组然后排序,获得两个排过序的数组mul和pro。但是接着我最琐碎的一步在于进行mul和pro间的比较,因为引用类型的比较不能直接用“==”进行,所以我只好挨个遍历值去比较。
但是别人的solution里,又将排过序的数组join成字符串了,直接用“==”比较,简单多了。
然后我回想了一下,发现自己经常想不起来用join这个函数,总是笨拙地在循环里用str+=“aaa”。
比如说另外一个练习:
Description:

Here we have a function that help us spam our hearty laughter. But is not working! I need you to find out why...

Expected results:

spam(1);//hue
spam(6);//huehuehuehuehuehue
spam(14);//huehuehuehuehuehuehuehuehuehuehuehuehuehue

这是我的做法:

function spam(number){
    var str="";
    for(var i=1;i<=number;i++){
        str+="hue";
    }
    return str;
}

然后别人用join函数只用了一行代码就解决了:

function spam(number){
    return Array(++number).join("hue");
}

说明

join函数:

定义和用法
join() 方法用于把数组中的所有元素放入一个字符串。
元素是通过指定的分隔符进行分隔的。

语法
arrayObject.join(separator)
separator可选。指定要使用的分隔符。如果省略该参数,则使用逗号作为分隔符。
[1]: http://www.codewars.com/

你可能感兴趣的:(code)