美文网首页
Basic Algorithm Scripting

Basic Algorithm Scripting

作者: skylin0909 | 来源:发表于2017-05-07 15:50 被阅读0次

    1.Reverse a String

    翻转字符串
    先把字符串转化成数组,再借助数组的reverse方法翻转数组顺序,最后把数组转化成字符串。
    reverseString("hello") 应该返回 "olleh".

    function reverseString(str) {
      return str.split("").reverse().join();
    }
    

    2.Factorialize a Number

    计算一个整数的阶乘
    如果用字母n来代表一个整数,阶乘代表着所有小于或等于n的整数的乘积。
    factorialize(20) 应该返回 2432902008176640000. factorialize(0) 应该返回 1.

    function factorialize(num) {
        if( num <= 1) {
          return 1;
        }else{
          return num * factorialize(num-1);
        }
    }
    

    3.Check for Palindromes

    如果给定的字符串是回文,返回true,反之,返回false。
    如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是回文。
    palindrome("A man, a plan, a canal. Panama") 应该返回 true.

    function palindrome(str) {
      var temp = str.replace(/[^A-Za-z0-9]/g,"").toLowerCase();
      return temp === temp.split("").reverse().join("");  
    }
    

    4.Find the Longest Word in a String

    找到提供的句子中最长的单词,并计算它的长度,
    函数的返回值应该是一个数字。
    findLongestWord("Google do a barrel roll") 应该返回 6

    function findLongestWord(str) {
      return str.split(" ").reduce(function(prev, next){
        return prev.length >= next.length ? prev : next;
      }).length;
    

    5.Title Case a Sentence

    确保字符串的每个单词首字母都大写,其余部分小写。像'the'和'of'这样的连接符同理。
    titleCase("sHoRt AnD sToUt") 应该返回 "Short And Stout".

    function titleCase(str) {
      var res = [];
      str.split(" ").map(function(item){
        var temp = item.slice(0,1).toUpperCase() + item.slice(1).toLowerCase();
        res.push(temp);
      });
      return res.join(" ");
    }
    

    6.Return Largest Numbers in Arrays

    右边大数组中包含了4个小数组,分别找到每个小数组中的最大值,然后把它们串联起来,形成一个新数组。
    largestOfFour([[4, 9, 1, 3], [13, 35, 18, 26], [32, 35, 97, 39], [1000000, 1001, 857, 1]]) 应该返回 [9, 35, 97, 1000000]

    function largestOfFour( arr ) {
      return [
        Math.max.apply(Math, arr[0]),
        Math.max.apply(Math, arr[1]),
        Math.max.apply(Math, arr[2]),
        Math.max.apply(Math, arr[3]),
      ];
    }
    

    7.Confirm the Ending

    检查一个字符串(str)是否以指定的字符串(target)结尾。如果是,返回true;如果不是,返回false。
    confirmEnding("He has to give me a new name", "name") 应该返回 true.

    function confirmEnding(str, target) {
     if (typeof String.prototype.endsWith !== 'function') {
     String.prototype.endsWith = function(ele) {
      return this.indexOf(ele,  this.length - ele.length) !== -1;
     };
    }
      return str.endsWith(target);
    }
    

    8.Repeat a string repeat a string

    重复一个指定的字符串 num次,如果num是一个负数则返回一个空字符串。
    repeat("abc", 4) 应该返回 "abcabcabcabc".

    function repeat(str, num) {
      if(num <= 0 ) return "";
      return str.repeat(num);
    }
    

    9.Truncate a string

    如果字符串的长度比指定的参数num长,则把多余的部分用...来表示。
    切记,插入到字符串尾部的三个点号也会计入字符串的长度。
    但是,如果指定的参数num小于或等于3,则添加的三个点号不会计入字符串的长度。
    truncate("A-", 1) 应该返回 "A...". truncate("Absolutely Longer", 2) 应该返回 "Ab...". truncate("Peppers", 8) 应该返回 "Peppers".

    function truncate(str, num) {
        if(num >= str.length){
            return str;
        }else if(num > 3 ){
            return str.slice(0, num-3) + "...";
       }else{
            return str.slice(0, num) + "...";
       }
    }
    

    10.Chunky Monkey

    把一个数组arr按照指定的数组大小size分割成
    chunk([0, 1, 2, 3, 4, 5, 6], 3) 应该返回 [[0, 1, 2], [3, 4, 5], [6]].

    function chunk(arr, size) {
      var res = [];
      for(var i = 0; i < arr.length; i+=size){
        res.push(arr.slice(i,i+size));
      }
      return res;
    }
    

    11.Slasher Flick

    返回一个数组被截断n个元素后还剩余的元素,截断从索引0开始。
    slasher([1, 2, 3], 2) 应该返回 [3]. slasher([1, 2, 3], 0) 应该返回 [1, 2, 3]. slasher([1, 2, 3], 9) 应该返回 [].

    function slasher(arr, howMany) {
      return arr.slice(howMany);
    }
    

    12.Mutations

    在忽略大小写的情况下,如果数组第一个字符串元素包含了第二个字符串元素的所有字符,函数返回true。
    mutation(["floor", "for"]) 应该返回 true. mutation(["hello", "Hello"]) 应该返回 true.

    function mutation(arr) {
      var temp = arr[0].toLowerCase().split("");
      return arr[1].toLowerCase().split("").every(function(item){
        return temp.includes(item);
      });
    }
    

    13.Falsy Bouncer

    删除数组中的所有假值。在JavaScript中,假值有false、null、0、""、undefined 和 NaN。
    bouncer([1, null, NaN, 2, undefined]) 应该返回 [1, 2].

    function bouncer(arr) {
      return arr.filter((item) => !!item);
    }
    

    14.Seek and Destroy

    实现一个摧毁(destroyer)函数,第一个参数是待摧毁的数组,其余的参数是待摧毁的值。
    destroyer([3, 5, 1, 2, 2], 2, 3, 5) 应该返回 [1]. destroyer([2, 3, 2, 3], 2, 3) 应该返回 [].

    function destroyer(...arr) {
      var [arr1,...arr2] = arr;
      return arr1.filter(function(item){
        return !arr2.includes(item);
      });
    }
    

    15.Where do I belong

    先给数组排序,然后找到指定的值在数组的位置,最后返回位置对应的索引。
    where([5, 3, 20, 3], 5) 应该返回 2. where([10, 20, 30, 40, 50], 30) 应该返回 2.

    function where(arr, num) {
      arr.push(num);
      return arr.sort(function(a,b){
        return a - b;
      }).indexOf(num);
    }
    

    16.Caesars Cipher

    下面我们来介绍风靡全球的凯撒密码Caesar cipher,又叫移位密码。
    rot13("SERR YBIR?") 应该解码为 "FREE LOVE?"

    function rot13(str) {
      return str.replace( /[A-Za-z]/g , function(c) { 
            return String.fromCharCode( c.charCodeAt(0) + ( c.toUpperCase() <= "M" ? 13 : -13 ) ); 
      });
    }
    

    相关文章

      网友评论

          本文标题:Basic Algorithm Scripting

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