简单点,就是想要一个好一点的未来,不想安于现状,我知道这个是必经之路,来吧!
我的一些心得:
- 每题答完,思考下有没有更好的解决方案
No.1: 查找数组元素位置
题目描述: 找出元素 item 在给定数组 arr 中的位置
输出描述: 如果数组中存在 item,则返回元素在数组中的位置,否则返回 -1
No.2: 数组求和
题目描述: 计算给定数组 arr 中所有元素的总和
输入描述: 数组中的元素均为 Number 类型
No.3: 移除数组中的元素
题目描述: 移除数组 arr 中的所有值与 item 相等的元素。不要直接修改数组 arr,结果返回新的数组
No.4: 移除数组中的元素
题目描述: 移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回
No.5:添加元素
题目描述: 在数组 arr 末尾添加元素 item。不要直接修改数组 arr,结果返回新的数组
No.6: 删除数组的最后一个元素
题目描述: 删除数组 arr 最后一个元素。不要直接修改数组 arr,结果返回新的数组
No.7: 叠筐
Problem Description
需要的时候,就把一个个大小差一圈的筐叠上去,使得从上往下看时,边筐花色交错。这个工作现在要让计算机来完成,得看你的了。
Input
输入是一个个的三元组,分别是,外筐尺寸n(n为满足0<n<80的奇整数),中心花色字符,外筐花色字符,后二者都为ASCII可见字符;
Output
输出叠在一起的筐图案,中心花色与外筐花色字符从内层起交错相叠,多筐相叠时,最外筐的角总是被打磨掉。叠筐与叠筐之间应有一行间隔。
Sample Input
11 B A
5 @ W
Sample Output
AAAAAAAAA
ABBBBBBBBBA
ABAAAAAAABA
ABABBBBBABA
ABABAAABABA
ABABABABABA
ABABAAABABA
ABABBBBBABA
ABAAAAAAABA
ABBBBBBBBBA
AAAAAAAAA
@@@
@WWW@
@W@W@
@WWW@
@@@
No.8: 添加元素
题目描述: 在数组 arr 开头添加元素 item。不要直接修改数组 arr,结果返回新的数组
No.9: 删除数组的第一个元素
题目描述: 删除数组 arr 第一个元素。不要直接修改数组 arr,结果返回新的数组
No.10: 数组合并
题目描述: 合并数组 arr1 和数组 arr2。不要直接修改数组 arr,结果返回新的数组
No.11: 添加元素
题目描述: 在数组 arr 的 index 处添加元素 item。不要直接修改数组 arr,结果返回新的数组
No.12: 计数
题目描述: 统计数组 arr 中值等于 item 的元素出现的次数
No.13: 查找重复元素
题目描述: 找出数组arr中重复出现过的元素
No.14: 求二次方
题目描述: 为数组 arr 中的每个元素求二次方。不要直接修改数组 arr,结果返回新的数组
N0.15: 查找元素位置
题目描述: 在数组 arr 中,查找值与 item 相等的元素出现的所有位置
No.16: 避免全局变量
题目描述: 给定的 js 代码中存在全局变量,请修复
No.17: 正确的函数定义
题目描述: 请修复给定的 js 代码中,函数定义存在的问题
No.18: 正确的使用parseInt
题目描述: 修改 js 代码中 parseInt 的调用方式,使之通过全部测试用例
No.19: 完全相等
题目描述: 判断 val1 和 val2 是否完全等同
No.20: 计时器
题目描述:
实现一个打点计时器,要求
1、从 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一个数字,每次数字增幅为 1
2、返回的对象中需要包含一个 cancel 方法,用于停止定时操作
3、第一个数需要立即输出
No.21: 流程控制
题目描述:
实现 fizzBuzz 函数,参数 num 与返回值的关系如下:
1、如果 num 能同时被 3 和 5 整除,返回字符串 fizzbuzz
2、如果 num 能被 3 整除,返回字符串 fizz
3、如果 num 能被 5 整除,返回字符串 buzz
4、如果参数为空或者不是 Number 类型,返回 false
5、其余情况,返回参数 num
例如输入15 返回fizzbuzz。
No.22: 函数传参
题目描述: 将数组 arr 中的元素作为调用函数 fn 的参数
输入:
function (greeting, name, punctuation) {return greeting + ', ' + name + (punctuation || '!');}, ['Hello', 'Ellie', '!']
输出:
Hello, Ellie!
No.23: 函数的上下文
题目描述: 将函数 fn 的执行上下文改为 obj 对象
输入:
function () {return this.greeting + ', ' + this.name + '!!!';}, {greeting: 'Hello', name: 'Rebecca'}
输出:
Hello, Rebecca!!!
No.24: 返回函数
题目描述:
实现函数 functionFunction,调用之后满足如下条件:
1、返回值为一个函数 f
2、调用返回的函数 f,返回值为按照调用顺序的参数拼接,拼接字符为英文逗号加一个空格,即 ', '
3、所有函数的参数数量为 1,且均为 String 类型
输入:
functionFunction('Hello')('world')
输出:
Hello, world
No.25: 使用闭包
题目描述
实现函数 makeClosures,调用之后满足如下条件:
1、返回一个函数数组 result,长度与 arr 相同
2、运行 result 中第 i 个函数,即 resulti,结果与 fn(arr[i]) 相同
输入
[1, 2, 3], function (x) {
return x * x;
}
输出
4
No.26: 二次封装函数
题目描述
已知函数 fn 执行需要 3 个参数。请实现函数 partial,调用之后满足如下条件:
1、返回一个函数 result,该函数接受一个参数
2、执行 result(str3) ,返回的结果与 fn(str1, str2, str3) 一致
输入
var sayIt = function(greeting, name, punctuation) { return greeting + ', ' + name + (punctuation || '!'); }; partial(sayIt, 'Hello', 'Ellie')('!!!');
输出
Hello, Ellie!!!
No.27: 使用arguments
题目描述: 函数 useArguments 可以接收 1 个及以上的参数。请实现函数 useArguments,返回所有调用参数相加后的结果。本题的测试参数全部为 Number 类型,不需考虑参数转换。
No.28: 使用apply调用函数
题目描述
实现函数 callIt,调用之后满足如下条件
1、返回的结果为调用 fn 之后的结果
2、fn 的调用参数为 callIt 的第一个参数之后的全部参数
No.29: 二次封装函数
题目描述:
实现函数 partialUsingArguments,调用之后满足如下条件:
1、返回一个函数 result
2、调用 result 之后,返回的结果与调用函数 fn 的结果一致
3、fn 的调用参数为 partialUsingArguments 的第一个参数之后的全部参数以及 result 的调用参数
No.30: 柯里化
题目描述:
已知 fn 为一个预定义函数,实现函数 curryIt,调用之后满足如下条件:
1、返回一个函数 a,a 的 length 属性值为 1(即显式声明 a 接收一个参数)
2、调用 a 之后,返回一个函数 b, b 的 length 属性值为 1
3、调用 b 之后,返回一个函数 c, c 的 length 属性值为 1
4、调用 c 之后,返回的结果与调用 fn 的返回值一致
5、fn 的参数依次为函数 a, b, c 的调用参数
输入
var fn = function (a, b, c) {return a + b + c}; curryIt(fn)(1)(2)(3);
输出
6
N0.31: 或运算
题目描述:
返回参数 a 和 b 的逻辑或运算结果
No.32: 且运算
题目描述: 返回参数 a 和 b 的逻辑且运算结果
No.33: 模块
题目描述
完成函数 createModule,调用之后满足如下要求:
1、返回一个对象
2、对象的 greeting 属性值等于 str1, name 属性值等于 str2
3、对象存在一个 sayIt 方法,该方法返回的字符串为 greeting属性值 + ', ' + name属性值
No.34: 二进制转换
题目描述
获取数字 num 二进制形式第 bit 位的值。注意:
1、bit 从 1 开始
2、返回 0 或 1
3、举例:2 的二进制为 10,第 1 位为 0,第 2 位为 1
输入
128, 8
输出
1
No.35: 二进制转换
题目描述
给定二进制字符串,将其换算成对应的十进制数字
输入
'11000000'
输出
192
No.36: 二进制转换
题目描述
将给定数字转换成二进制字符串。如果字符串长度不足 8 位,则在前面补 0 到满8位。
输入
65
输出
01000001
No.37: 乘法
题目描述
求 a 和 b 相乘的值,a 和 b 可能是小数,需要注意结果的精度问题
输入
3, 0.0001
输出 0.0003
No.38: 改变上下文
题目描述:
将函数 fn 的执行上下文改为 obj,返回 fn 执行后的值
输入
alterContext(function() {return this.greeting + ', ' + this.name + '!'; }, {name: 'Rebecca', greeting: 'Yo' })
输出
Yo, Rebecca!
No.39: 批量改变对象的属性
题目描述:
给定一个构造函数 constructor,请完成 alterObjects 方法,将 constructor 的所有实例的 greeting 属性指向给定的 greeting 变量。
输入
var C = function(name) {this.name = name; return this;};
var obj1 = new C('Rebecca');
alterObjects(C, 'What\'s up'); obj1.greeting;
输出
What's up
No.40: 属性遍历
题目描述
找出对象 obj 不在原型链上的属性(注意这题测试例子的冒号后面也有一个空格~) 1、返回数组,格式为 key: value 2、结果数组不要求顺序
输入
var C = function() {this.foo = 'bar'; this.baz = 'bim';};
C.prototype.bop = 'bip';
iterate(new C());
输出
["foo: bar", "baz: bim"]
No.41: 判断是否包含数字
题目描述
给定字符串 str,检查其是否包含数字,包含返回 true,否则返回 false
输入
'abc123'
输出
true
No.42: 检查重复字符串
题目描述
给定字符串 str,检查其是否包含连续重复的字母(a-zA-Z),包含返回 true,否则返回 false
输入
'rattler'
输出
true
No.43: 判断是否以原音字母结尾
题目描述
给定字符串 str,检查其是否以元音字母结尾
1、元音字母包括 a,e,i,o,u,以及对应的大写
2、包含返回 true,否则返回 false
输入
'gorilla'
输出
true
No.44: 获取指定字符串
题目描述
给定字符串 str,检查其是否包含 连续3个数字
1、如果包含,返回最新出现的 3 个数字的字符串
2、如果不包含,返回 false
输入
'9876543'
输出
987
No.45: 判断是否符合指定格式
题目描述
给定字符串 str,检查其是否符合如下格式 1、XXX-XXX-XXXX 2、其中 X 为 Number 类型
输入
'800-555-1212'
输出
true
No.46: 判断是否符合USD格式
题目描述
给定字符串 str,检查其是否符合美元书写格式 1、以 $ 开始 2、整数部分,从个位起,满 3 个数字用 , 分隔 3、如果为小数,则小数部分长度为 2 4、正确的格式如:$1,023,032.03 或者 $2.03,错误的格式如:$3,432,12.12 或者 $34,344.3
输入
'$20,933,209.93'
输出
true
No.47: 修改this指向
题目描述:
封装函数 f,使 f 的 this 指向指定的对象
No.48: 获取url参数
题目描述:
获取 url 中的参数
-
指定参数名称,返回该参数的值 或者 空字符串
-
不指定参数名称,返回全部的参数对象 或者 {}
-
如果存在多个同名参数,则返回数组
No.49: 加粗文字
题目描述:
使用一个标签将“牛客网”三个字加粗显示
No.50: 段落标识
题目描述
请将下面这句话已段落的形式展示在浏览器中——“牛客网是一个专注于程序员的学习和成长的专业平台。”
No.51: 设置文字颜色
题目描述:
请使用嵌入样式将所有p标签设置为红色文字
No.52: 数组去重
题目描述:
为 Array 对象添加一个去除重复项的方法
输入
[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a', NaN]
输出
[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']
No.53: 斐波那契数列
题目描述
用 JavaScript 实现斐波那契数列函数,返回第n个斐波那契数。 f(1) = 1, f(2) = 1 等
No.54: 字符串字符统计
题目描述:
统计字符串中每个字符的出现频率,返回一个 Object,key 为统计字符,value 为出现频率
-
不限制 key 的顺序
-
输入的字符串参数不会为空
-
忽略空白字符
输入
'hello world'
输出
{h: 1, e: 1, l: 3, o: 2, w: 1, r: 1, d: 1}
No.55: 将字符串转换为驼峰格式
题目描述:
css 中经常有类似 background-image 这种通过 - 连接的字符,通过 javascript 设置样式的时候需要将这种样式转换成 backgroundImage 驼峰格式,请完成此转换功能
-
以 - 为分隔符,将第二个起的非空单词首字母转为大写
-
-webkit-border-image 转换后的结果为 webkitBorderImage
输入
'font-size'
输出
fontSize
No.56: 颜色字符串转换
题目描述
将 rgb 颜色字符串转换为十六进制的形式,如 rgb(255, 255, 255) 转为 #ffffff
-
rgb 中每个 , 后面的空格数量不固定
-
十六进制表达式使用六位小写字母
-
如果输入不符合 rgb 格式,返回原始输入
输入
'rgb(255, 255, 255)'
输出
#ffffff
No.57: 邮箱字符串判断
题目描述:
判断输入是否是正确的邮箱格式
No.58: 获取字符串长度
题目描述
如果第二个参数 bUnicode255For1 === true,则所有字符长度为 1
否则如果字符 Unicode 编码 > 255 则长度为 2
输入
'hello world, 牛客', false
输出
17
No59: 时间格式化输出
题目描述
按所给的时间格式输出指定的时间
格式说明
对于 2014.09.05 13:14:20
yyyy: 年份,2014
yy: 年份,14
MM: 月份,补满两位,09
M: 月份, 9
dd: 日期,补满两位,05
d: 日期, 5
HH: 24制小时,补满两位,13
H: 24制小时,13
hh: 12制小时,补满两位,01
h: 12制小时,1
mm: 分钟,补满两位,14
m: 分钟,14
ss: 秒,补满两位,20
s: 秒,20
w: 星期,为 ['日', '一', '二', '三', '四', '五', '六'] 中的某一个,本 demo 结果为 五
输入
formatDate(new Date(1409894060000), 'yyyy-MM-dd HH:mm:ss 星期w')
输出
2014-09-05 13:14:20 星期五
No.60: 根据包名,在指定空间创建对象
题目描述
根据包名,在指定空间中创建对象
输入描述:
namespace({a: {test: 1, b: 2}}, 'a.b.c.d')
输出描述:
{a: {test: 1, b: {c: {d: {}}}}}
No.61: DOM节点查找
题目描述
查找两个节点的最近的一个共同父节点,可以包括节点自身
输入描述:
oNode1 和 oNode2 在同一文档中,且不会为相同的节点
题目描述:
实现一个函数fn,该函数有一个参数n(数字类型),其返回值是一个数组。数组内是n个随机不重复的整数,且整数取值范围是[2,32]