转载:http://www.bubuko.com/infodetail-20477.html

题目一:找出数字数组中最大的元素

  1.  
    var arr=[0,1,2,3,4,5,6,7,8,9];
  2.  
    console.log(Math.max.apply(null,arr))

题目二:转化一个数字数组为function数组(每个function都弹出相应的数字)

for循环闭包的问题

  1.  
    var arr=[0,1,2,3,4,5,6,7,8,9],arrFunc = [];
  2.  
    for(var i = 0, l = arr.length; i < l; i++){
  3.  
    arrFunc.push((function(i) {
  4.  
    return function() {
  5.  
    console.log(arr[i]);
  6.  
    }
  7.  
    })(i))
  8.  
    }

题目三:给object数组进行排序(排序条件是每个元素对象的属性个数)

  1.  
    Object.prototype.myLength = function(){
  2.  
    var length = 0;
  3.  
    for(var i in this){
  4.  
    length ++;
  5.  
    }
  6.  
    return length;
  7.  
    }
  8.  
    var objArr = [
  9.  
    {a:1, b:2, c:5, d:7, e:8, g:0, h:12, i:5, v:9, w:9, x:9, y:9, z: 15},
  10.  
    {a:2, b:2, c:5, d:7, e:8, g:0, h:12, i:5, j:7, k:5, l:9, m:9, n:0, o:1, p:9, x:9, y:9, z:9 },
  11.  
    {a:3, b:2, c:5, d:7, e:8, g:0, h:12, i:5, j:7, k:5, l:9, m:9, n:0, o:1, p:9, q:0 },
  12.  
    {a:4, b:2, c:5, d:7, e:8, g:0, h:12, i:5, j:7, k:5, w:9, x:9, y:9, z:9 },
  13.  
    {a:5, b:2, c:5, d:7, e:8, g:0, h:12, i:5, j:7, k:5, v:9, w:9, x:9, y:9, z:9 },
  14.  
    {a:6, b:2, c:5, d:7, e:8, g:0, h:12, i:5, j:7, k:5, l:9, m:9, n:0, o:1, p:9, q:0, r:8, s:9, t:9, z:9 },
  15.  
    {a:7, b:2, c:5, d:7, e:8, x:9, y:9, z:9 }
  16.  
    ];
  17.  
    // arr before sort
  18.  
    var numArr1 = []
  19.  
    for(var i = 0, l = objArr.length; i < l; i++ ){
  20.  
    numArr1.push( objArr[i].myLength() )
  21.  
    }
  22.  
    console.log(numArr1.join(" ")) //result
  23.  
    // arr after sort
  24.  
    objArr.sort(function(a,b){
  25.  
    // stable sort
  26.  
    // return (a.myLength() > b.myLength()) === true? 1:-1;
  27.  
    // unstable sort
  28.  
    return (a.myLength() >= b.myLength()) === true? 1:-1;
  29.  
    // return a.myLength() - b.myLength();
  30.  
    })
  31.  
    var numArr2 = []
  32.  
    for(var i = 0, l = objArr.length; i < l; i++ ){
  33.  
    // console.log(i,l,objArr[i].myLength());
  34.  
    numArr2.push( objArr[i].myLength() )
  35.  
    }
  36.  
    console.log(numArr2.join(" ")) //result

题目四:利用JavaScript打印出Fibonacci数(不使用全局变量)

  1.  
    var fibonacci = (function(){
  2.  
    var s = [];
  3.  
    var fun = function(x) {
  4.  
    if(s[x]){
  5.  
    return s[x];
  6.  
    }
  7.  
    if(x < 0) {
  8.  
    throw "Can‘t be negative";
  9.  
    return ;
  10.  
    }
  11.  
    else if(x === 0 || x === 1) {
  12.  
    s[x] = s[x] || x;
  13.  
    return s[x];
  14.  
    }
  15.  
    else{
  16.  
    s[x] = ( fun(x - 1) + fun(x - 2) );
  17.  
    return s[x];
  18.  
    }
  19.  
    };
  20.  
    fun.print = function() {
  21.  
    console.log(s.join(" "));
  22.  
    }
  23.  
    fun.printLast = function() {
  24.  
    // console.log(s.length);
  25.  
    return(s[s.length-1]);
  26.  
    }
  27.  
    window.s = s;
  28.  
    return fun;
  29.  
     
  30.  
    })()
  31.  
    console.time(200);
  32.  
    console.log(fibonacci(200));
  33.  
    console.log(fibonacci.printLast());
  34.  
    console.log(fibonacci.print());
  35.  
    console.timeEnd(200);
  1.  
    var fibonacci2 = function(x){
  2.  
    if(x < 0) {
  3.  
    throw "Can‘t be negative";
  4.  
    return ;
  5.  
    }
  6.  
    if(x === 0 || x === 1) {
  7.  
    return x;
  8.  
    }
  9.  
    var num = ( fibonacci2(x - 1) + fibonacci2(x - 2) )
  10.  
    return num;
  11.  
    }
  12.  
    console.time(32);
  13.  
    console.log(fibonacci2(32));
  14.  
    console.timeEnd(32);

题目五:实现如下语法的功能:var a = (5).plus(3).minus(6);

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

题目六:实现如下语法的功能:var a = add(2)(3)(4);

  1.  
    function add(x) {
  2.  
    var mid;
  3.  
    mid = x || 0;
  4.  
    function addObj(x) {
  5.  
    x = x || 0;
  6.  
    mid = mid + x;
  7.  
    return addObj;
  8.  
    }
  9.  
    addObj.valueOf = function() {
  10.  
    return mid;
  11.  
    }
  12.  
    addObj.toString = function() {
  13.  
    return mid;
  14.  
    }
  15.  
    return addObj;
  16.  
    }
  17.  
    //call the obj.valueOf function
  18.  
    console.log(add(2));
  19.  
    console.log(add(2)(3));
  20.  
    console.log(add(2)(3)(4));
  21.  
    console.log(add(2)(3)(4)(5));
  22.  
     
  23.  
    //call the obj.toString function
  24.  
    alert(add(2));
  25.  
    alert(add(2)(3));
  26.  
    alert(add(2)(3)(4));
  27.  
    alert(add(2)(3)(4)(5));

js的6道基础题(笔试常考题)的更多相关文章

  1. 各位大佬Python的第一部分道基础题已经整理好了,希望大家面试的时候能用的上。

    Python的第一部分道基础题,希望大家面试的时候能用的上. 1.为什么学习Python? Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途 ...

  2. 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester

    这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...

  3. 朋友去面试Python工程师,又带回来几道基础题,Python面试题No10

    第1题: print 调用 Python 中底层的什么方法? print print() 用 sys.stdout.write() 实现 import sys print('hello') sys.s ...

  4. Java基础知识强化11:多态的两道基础题

    1.第1题 class Base { public void method() { System.out.print("Base method"); } } class Child ...

  5. 关于js的几道经典题(作用域、原型链等)自己做的

    1. function test() { var a = 1; setTimeout(function() { alert(a); a = 3; }, 1000); a = 2; setTimeout ...

  6. 关于SQL的几道小题详解

    关于SQL的几道小题详解 当我们拿到题目的时候,并不是急于作答,那样会得不偿失的,而是分析思路,采用什么方法,达到什么目的,还要思考有没有简单的方法或者通用的方法等等,这样才会达到以一当十的效果,这样 ...

  7. 《JS修炼之道》—— 读后总结

    本篇是基于<JS修炼之道>的记录性与总结性的文章,这本书从多种框架的角度,讲述了JS开发中的一些实用技巧. 比如Prototype,JQuery,Mootools,YUI,Dojo,Ext ...

  8. 小试牛刀2:JavaScript基础题

    JavaScript基础题 1.网页中有个字符串“我有一个梦想”,使用JavaScript获取该字符串的长度,同时输出字符串最后两个字. 答案: <!DOCTYPE html PUBLIC &q ...

  9. [2]十道算法题【Java实现】

    前言 清明不小心就拖了两天没更了-- 这是十道算法题的第二篇了-上一篇回顾:十道简单算法题 最近在回顾以前使用C写过的数据结构和算法的东西,发现自己的算法和数据结构是真的薄弱,现在用Java改写一下, ...

随机推荐

  1. Redis主从结构主节点执行写入后wait命令对性能的影响

    这里的Redis主从结构可以是简单的主从,sentinel,redis cluster中的主从等. wait命令的作用:此命令将阻塞当前客户端,直到当前Session连接(主节点上)所有的写命令都被传 ...

  2. for _ in range(n) python里那些奇奇怪怪的语法糖

    for _ in range(n)中 _ 是占位符, 表示不在意变量的值 只是用于循环遍历n次. 例如在一个序列中只想取头和尾,就可以使用_ 其实意思和for each in range(n)是一个意 ...

  3. SpringBoot图文教程6—SpringBoot中过滤器的使用

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文系列教程技术大纲 鹿老师的Java笔记 SpringBo ...

  4. C# Excel导出超出65536行报错 Invalid row number (65536) outside allowable range (0..65535)

    C# Excel导出超出65536行报错 Invalid row number (65536) outside allowable range (0..65535) 一:报错 Invalid row ...

  5. Android中创建一个BroadcastReceiver

    首先创建一个java类继承BroadcastReceiver类 package com.example.service; import android.content.BroadcastReceive ...

  6. tomcat - class sun.awt.X11GraphicsEnvironment异常处理

    原因导致 经过Google发现很多人也出现同样的问题.从了解了X11GraphicEnvironment这个类的功能入手,一个Java服务器来处理图片的API基本上是需要运行一个X-server以便能 ...

  7. codechef Scoring Pairs

    难度 \(medium-hard\) 题意 官方中文题意 做法 很显然是可以通过计算常数个\(sum(A,B)=\sum\limits_{i=0}^A \sum\limits_{j=0}^B scor ...

  8. CVE-2019-1388 UAC提权复现

    0x01 前言 该漏洞位于Windows的UAC(User Account Control,用户帐户控制)机制中.默认情况下,Windows会在一个单独的桌面上显示所有的UAC提示--Secure D ...

  9. Jackson使用指南

    Jackson常用注解 序列化注解 @JsonAnyGetter 像普通属性一样序列化Map public class ExtendableBean { public String name; pri ...

  10. linux服务基础之编译安装nginx

    nginx源码下载地址: http://nginx.org/download/nginx-1.16.0.tar.gz //根据需要下载其他版本 1. 下载nginx # wget http://ngi ...