美文网首页
FreeCodeCamp-JavaScript中级算法题

FreeCodeCamp-JavaScript中级算法题

作者: 不要吧我再睡会 | 来源:发表于2017-02-15 16:22 被阅读0次

    1.Sum All Numbers in a Range
    我们会传递给你一个包含两个数字的数组。返回这两个数字和它们之间所有数字的和。最小的数字并非总在最前面。

    答:
    <pre>
    function sumAll(arr) {
    var min = Math.min(arr[0],arr[1]);
    var max = Math.max(arr[0],arr[1]);
    var newArr = [];
    for(var i=0;i<=max-min;i++){
    newArr[i] = min+i;
    }
    return newArr.reduce(function(a,b){return a+b;});
    }
    sumAll([1, 4]);
    </pre>
    解:其实数组里面只有2个数字的话,也可以用<code>sort()</code>方法排序,然后<code>arr[0]</code>,<code>arr[1]</code>就分别是最小值和最大值。这题的解法在for循环,创建一个新数组,来接收每次循环得到的数字。最后对新数组<code>reduce()</code>方法得到新数组里面每个数字累加的结果。

    2.Diff Two Arrays
    比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差异。

    答:
    <pre>
    function diff(arr1, arr2) {
    var newArr1 = arr1.filter(function(item,index,array){//item是arr1里面的元素
    return arr2.indexOf(item) ===-1;//找出arr2中与arr1中不同的元素
    });
    var newArr2 = arr2.filter(function(item,index,array){
    return arr1.indexOf(item) ===-1;
    });
    return newArr1.concat(newArr2);
    }
    diff([1, 2, 3, 5], [1, 2, 3, 4, 5]);
    </pre>
    解:返回差异值,利用filter()方法来返回<code>indexOf()</code>为-1的元素即可。

    3.Roman Numeral Converter
    将给定的数字转换成罗马数字。
    所有返回的 罗马数字 都应该是大写形式。

    答:
    <pre>
    function convert(num) {
    var nums = [1000,900,500,400,100,90,50,40,10,9,5,4,1];
    var romans =["m","cm","d","cd","c","xc","l","xl","x","ix","v","iv","i"];
    var str = '';
    nums.forEach(function(item,index,array){
    while(num >= item){
    str += romans[index];
    num -= item;
    }
    });
    return str.toUpperCase();
    }
    convert(4);
    </pre>

    相关文章

      网友评论

          本文标题:FreeCodeCamp-JavaScript中级算法题

          本文链接:https://www.haomeiwen.com/subject/ardzvttx.html