• 汤姆大叔的6道javascript编程题题解


    1、找出数字数组中最大的元素(使用Math.max函数)

    1
    2
    3
    var a = [1, 2, 3, 6, 5, 4];
    var ans = Math.max.apply(null, a);
    console.log(ans);  // 6

      这题很巧妙地用了apply,如果不是数组,是很多数字求最大值,我们知道可以这样:

    1
    2
    var ans = Math.max(1, 2, 3, 4, 5, 6);
    console.log(ans); // 6

      而apply的第二个参数正是一个数组,都不用进行转换了。

      还有一种用eval+toString的实现:

    1
    2
    3
    var a = [1, 2, 3, 6, 5, 4];
    var ans = eval( 'Math.max(' + a.toString() + ')');
    console.log(ans); // 6

    2、转化一个数字数组为function数组(每个function都弹出相应的数字)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    var a = [1, 2, 3, 4, 5, 6];
    var len = a.length;
    for(var i = 0; i < len; i++) {
      var num = a[i];
      (function(num) {
        var f = function() {
          console.log(num);
        };
        a[i] = f;
      })(num);
    }
     
    for(var i = 0; i < len; i++)
      a[i]();
    // 1
    // 2
    // 3
    // 4
    // 5
    // 6

      我觉得这跟给n个a标签,弹出相应标签对应的编号是一个类型的题,用闭包保存变量到内存即可。

    3、给object数组进行排序(排序条件是每个元素对象的属性个数)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    var a = {
      name: 'hanzichi',
      age: 10,
      location: 'china'
    };
     
    var b = {
      name: 'curry'
    };
     
    var c = {
      name: 'kobe',
      sex: 'male'
    };
     
    Object.prototype.getLength =  function() {
      var num = 0;
      for(var key in this) {
        if(this.hasOwnProperty(key))
          num++;
      }
      return num;
    };
     
    var arr = [a, b, c];
    arr.sort(function(a, b) {
      return a.getLength() > b.getLength();
    });
    console.log(arr);

      这题不难,数组排序,当然是sort,排序条件是对象的属性个数,可以写个函数计算,注意可能要用hasOwnProperty判断下。

    4、利用JavaScript打印出Fibonacci数(不使用全局变量)

    1
    2
    3
    4
    5
    6
    (function(a, b) {
      var c = a + b;
      console.log(c);
      if(c > 100) return;
      arguments.callee(b, c);
    })(-1, 1);

      这题没看明白,是打出斐波那契数列的前n项么?还是第n项...

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    function fn(n) {
      var a = [];
      a[0] = 0, a[1] = 1;
      for(var i = 2; i < n; i++)
        a[i] = a[i - 1] + a[i - 2];
      for(var i = 0; i < n; i++)
        console.log(a[i]);
    }
     
    fn(5); // 10表示需要的斐波那契数列个数
    // 0
    // 1
    // 1
    // 2
    // 3

      不使用全局变量,我把它们写在函数里了应该算是局部变量了吧,难道这样就好了?你怎么看?

    5、实现如下语法的功能:var a = (5).plus(3).minus(6); //2

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Number.prototype.plus = function(a) {
      return this + a;
    };
     
    Number.prototype.minus = function(a) {
      return this - a;
    };
     
    var a = (5).plus(3).minus(6);
    console.log(a); // 2

      直接在Number对象上加扩展方法即可,传说中这样很不好,but我也想不到更好的办法了...

    6、实现如下语法的功能:var a = add(2)(3)(4); //9

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function add(a) {
      var temp = function(b) {
        return add(a + b);
      }
      temp.valueOf = temp.toString = function() {
        return a;
      };
      return temp;
    }
    var ans = add(2)(3)(4);
    console.log(ans); // 9

      对valueOf和toString的考察,具体可以参考《valueOf和toString》 

      另看到一种很飘逸的写法(来自Gaubee):

    1
    2
    3
    4
    5
    6
    7
    8
    function add(num){
      num += ~~add;
      add.num = num;
      return add;
    }
    add.valueOf = add.toString = function(){return add.num};
    var ans = add(3)(4)(5)(6);  // 18
    alert(ans);

     

  • 相关阅读:
    【学习笔记】斯特林数(未完成)
    【题解/学习笔记】点分树
    【题解】[国家集训队] Crash 的文明世界
    【题解】SP34096 DIVCNTK
    【题解】Loj6053 简单的函数
    【题解】[ZJOI2012]网络
    【题解】bzoj3252 攻略
    【题解】[POI2014]HOT-Hotels 加强版
    IDEA文件夹变红,轻松删除SVN版本控制关联
    配置dataguard broker并主从切换
  • 原文地址:https://www.cnblogs.com/JohnLiang/p/5715771.html
Copyright © 2020-2023  润新知