js的6道基础题(笔试常考题)
转载:http://www.bubuko.com/infodetail-20477.html
题目一:找出数字数组中最大的元素
- var arr=[0,1,2,3,4,5,6,7,8,9];
- console.log(Math.max.apply(null,arr))
题目二:转化一个数字数组为function数组(每个function都弹出相应的数字)
for循环闭包的问题
- var arr=[0,1,2,3,4,5,6,7,8,9],arrFunc = [];
- for(var i = 0, l = arr.length; i < l; i++){
- arrFunc.push((function(i) {
- return function() {
- console.log(arr[i]);
- }
- })(i))
- }
题目三:给object数组进行排序(排序条件是每个元素对象的属性个数)
- Object.prototype.myLength = function(){
- var length = 0;
- for(var i in this){
- length ++;
- }
- return length;
- }
- var objArr = [
- {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},
- {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 },
- {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 },
- {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 },
- {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 },
- {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 },
- {a:7, b:2, c:5, d:7, e:8, x:9, y:9, z:9 }
- ];
- // arr before sort
- var numArr1 = []
- for(var i = 0, l = objArr.length; i < l; i++ ){
- numArr1.push( objArr[i].myLength() )
- }
- console.log(numArr1.join(" ")) //result
- // arr after sort
- objArr.sort(function(a,b){
- // stable sort
- // return (a.myLength() > b.myLength()) === true? 1:-1;
- // unstable sort
- return (a.myLength() >= b.myLength()) === true? 1:-1;
- // return a.myLength() - b.myLength();
- })
- var numArr2 = []
- for(var i = 0, l = objArr.length; i < l; i++ ){
- // console.log(i,l,objArr[i].myLength());
- numArr2.push( objArr[i].myLength() )
- }
- console.log(numArr2.join(" ")) //result
题目四:利用JavaScript打印出Fibonacci数(不使用全局变量)
- var fibonacci = (function(){
- var s = [];
- var fun = function(x) {
- if(s[x]){
- return s[x];
- }
- if(x < 0) {
- throw "Can‘t be negative";
- return ;
- }
- else if(x === 0 || x === 1) {
- s[x] = s[x] || x;
- return s[x];
- }
- else{
- s[x] = ( fun(x - 1) + fun(x - 2) );
- return s[x];
- }
- };
- fun.print = function() {
- console.log(s.join(" "));
- }
- fun.printLast = function() {
- // console.log(s.length);
- return(s[s.length-1]);
- }
- window.s = s;
- return fun;
- })()
- console.time(200);
- console.log(fibonacci(200));
- console.log(fibonacci.printLast());
- console.log(fibonacci.print());
- console.timeEnd(200);
- var fibonacci2 = function(x){
- if(x < 0) {
- throw "Can‘t be negative";
- return ;
- }
- if(x === 0 || x === 1) {
- return x;
- }
- var num = ( fibonacci2(x - 1) + fibonacci2(x - 2) )
- return num;
- }
- console.time(32);
- console.log(fibonacci2(32));
- console.timeEnd(32);
题目五:实现如下语法的功能:var a = (5).plus(3).minus(6);
- Number.prototype.plus = function(x) {
- var num = this.valueOf() + x;
- return Number(num);
- }
- Number.prototype.minus = function(x) {
- var num = this.valueOf() - x;
- return Number(num);
- }
- var a = (5).plus(3).minus(6);
- console.log(a);
- alert(a);
题目六:实现如下语法的功能:var a = add(2)(3)(4);
- function add(x) {
- var mid;
- mid = x || 0;
- function addObj(x) {
- x = x || 0;
- mid = mid + x;
- return addObj;
- }
- addObj.valueOf = function() {
- return mid;
- }
- addObj.toString = function() {
- return mid;
- }
- return addObj;
- }
- //call the obj.valueOf function
- console.log(add(2));
- console.log(add(2)(3));
- console.log(add(2)(3)(4));
- console.log(add(2)(3)(4)(5));
- //call the obj.toString function
- alert(add(2));
- alert(add(2)(3));
- alert(add(2)(3)(4));
- alert(add(2)(3)(4)(5));
js的6道基础题(笔试常考题)的更多相关文章
- 各位大佬Python的第一部分道基础题已经整理好了,希望大家面试的时候能用的上。
Python的第一部分道基础题,希望大家面试的时候能用的上. 1.为什么学习Python? Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途 ...
- 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester
这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...
- 朋友去面试Python工程师,又带回来几道基础题,Python面试题No10
第1题: print 调用 Python 中底层的什么方法? print print() 用 sys.stdout.write() 实现 import sys print('hello') sys.s ...
- Java基础知识强化11:多态的两道基础题
1.第1题 class Base { public void method() { System.out.print("Base method"); } } class Child ...
- 关于js的几道经典题(作用域、原型链等)自己做的
1. function test() { var a = 1; setTimeout(function() { alert(a); a = 3; }, 1000); a = 2; setTimeout ...
- 关于SQL的几道小题详解
关于SQL的几道小题详解 当我们拿到题目的时候,并不是急于作答,那样会得不偿失的,而是分析思路,采用什么方法,达到什么目的,还要思考有没有简单的方法或者通用的方法等等,这样才会达到以一当十的效果,这样 ...
- 《JS修炼之道》—— 读后总结
本篇是基于<JS修炼之道>的记录性与总结性的文章,这本书从多种框架的角度,讲述了JS开发中的一些实用技巧. 比如Prototype,JQuery,Mootools,YUI,Dojo,Ext ...
- 小试牛刀2:JavaScript基础题
JavaScript基础题 1.网页中有个字符串“我有一个梦想”,使用JavaScript获取该字符串的长度,同时输出字符串最后两个字. 答案: <!DOCTYPE html PUBLIC &q ...
- [2]十道算法题【Java实现】
前言 清明不小心就拖了两天没更了-- 这是十道算法题的第二篇了-上一篇回顾:十道简单算法题 最近在回顾以前使用C写过的数据结构和算法的东西,发现自己的算法和数据结构是真的薄弱,现在用Java改写一下, ...
随机推荐
- 单源最短路 Bellman-Ford算法(有向图)
// 单源最短路问题 // Bellman-Ford算法 // 复杂度O(V*E) //! 可以判断负圈 #include <cstdio> #include <iostream&g ...
- vmware进程,虚拟机NAT模式配置固定ip,访问外网与ping通主机
vmware进程杀不掉 在使用vmware虚拟机时,如果强制结束vmware进程,可能会发现在资源监视器中有一个vmware-vmx.exe进程始终关不掉,获得管理员权限去杀或者重启都没有用,然后正常 ...
- Percona Xtrabackup 备份工具
生成备份 $ xtrabackup --backup --target-dir=/data/backups/ 注:--target-dir可以放在my.cnf配置文件中.如果指定的目录不存在,xtra ...
- mysql 行级锁问题
线上碰到存储过程死锁问题了,开始以为非主键查询 for update 会导致表锁,后来经过测试 innodb下for update索引生效的情况下 根据索引字段查询是行级锁,会将整个结果集进行上锁,直 ...
- 如何选择JavaScript构建工具之Babel、Browserify、Webpack、Grunt以及Gulp
当我们开始一个新的 JavaScript 项目时,我们需要考虑的第一件事就是搭建一个前端编译环境.但是在面对众多的 JavaScript 构建工具时,我们却无所适从,不知道究竟哪一个才是最适合我们的. ...
- 【Spring】事务(transactional)之初步理解
一. 场景 有一个定时器,做数据库表数据同步. 把数据库A的表table(DB_A_TABLE)同步到数据库B的表table(DB_B_TABLE). 对于DB_A_TABLE的每行数据要做一定的逻辑 ...
- iptables (二) nat & tcp_wrapper
一.nat 之前网络防火墙的示例中,如果内网是私网地址,那么内网主机如何与外网通信呢? 这时候,iptables要实现内网和外网通信,有两种方式: nat: Network Address Trans ...
- docker镜像alpine封装nginx1.16.1【dockerfile】
github地址:https://github.com/laileman/Docker/Dockerfile/alpine-nginx1.16.1 1-目录结构 2- dockerfile内容 3- ...
- tp5使用PHPexcel扩展导出excel表
1,使用composer安装phpexcel包: composer require phpoffice/phpexcel 2,在控制器中创建方法: (1)使用PHPexcel扩展.代码如下 /** * ...
- ArcGISServer发布流程
发布数据服务 在进行WebGIS开发中,地图显示的内容可以分成两类:一类是底图,或者是矢量的世界地图.中国地图.某个地区的底图:另一类就是业务图,对于用于遥感数据发布的WebGIS应用就是遥感影像的边 ...