24、柯里化

首先想解释一下,“柯里化”的意思,

【在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术由 Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。】——from 百度百科

题目描述

已知 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
function curryIt(fn) {
return a=function(aa){
return b=function(bb){
return c=function(cc){
return fn(aa,bb,cc);
}
}
}
}

25、或运算

题目描述

返回参数 a 和 b 的逻辑或运算结果

输入例子:
or(false, true)
输出例子:
true
function or(a, b) {
return a||b;
}

26、且运算

题目描述

返回参数 a 和 b 的逻辑且运算结果

输入例子:
and(false, true)
输出例子:
false
function and(a, b) {
return a&&b;
}

27、模块

题目描述

完成函数 createModule,调用之后满足如下要求: 1、返回一个对象 2、对象的 greeting 属性值等于 str1, name 属性值等于 str2 3、对象存在一个 sayIt 方法,该方法返回的字符串为 greeting属性值 + ', ' + name属性值
function createModule(str1, str2) {
var obj={
greeting :str1,
name :str2,
sayIt :function(){
return this.greeting+', '+this.name ;
}
};
return obj;
}

这里注意下:在连接两个字符的逗号 后面一定要加上空格,即写成这样:  ', '  而不是   ','    否则就不会是100%通过case。

28、二进制转换

题目描述

获取数字 num 二进制形式第 bit 位的值。注意: 1、bit 从 1 开始 2、返回 0 或 1 3、举例:2 的二进制为 10,第 1 位为 0,第 2 位为 1

输入例子:
valueAtBit(128, 8)
输出例子:
1
function valueAtBit(num, bit) {
var biNum=num.toString(2);
return biNum[biNum.length-bit];
}

先将10进制数,转换成2进制数,用带参数的toString方法。
29、二进制转换

题目描述

给定二进制字符串,将其换算成对应的十进制数字

输入例子:
base10('11000000')
输出例子:
192
function base10(str) {
return parseInt(str,2);
}

将2进制数转换成10进制数使用parseInt方法,带两个参数
parseInt(string, radix)

string 必需。要被解析的字符串。
radix

可选。表示要解析的数字的基数。该值介于 2 ~ 36 之间。

更多parseInt介绍参见:http://www.w3school.com.cn/jsref/jsref_parseInt.asp

30、二进制转换

题目描述

将给定数字转换成二进制字符串。如果字符串长度不足 8 位,则在前面补 0 到满8位。

输入例子:
convertToBinary(65)
输出例子:
01000001
function convertToBinary(num) {
var biNum=num.toString(2); if(biNum.length<8){
for(var i=0;i<8-biNum.length;i++)
biNum="0"+biNum;
}
return biNum;
}
31、乘法

题目描述

求 a 和 b 相乘的值,a 和 b 可能是小数,需要注意结果的精度问题

输入例子:
multiply(3, 0.0001)
输出例子:
0.0003
function multiply(a, b) {
return a*b;
}
看来直接相乘即可保证小数点后的为数不会丢失。若想控制小数点后位数可使用方法 toFixed(2)  参数2的意义是保留小数点后2位数,可根据需要设置。
32、改变上下文

题目描述

将函数 fn 的执行上下文改为 obj,返回 fn 执行后的值

输入例子:
alterContext(function() {return this.greeting + ', ' + this.name + '!'; }, {name: 'Rebecca', greeting: 'Yo' })
输出例子:
Yo, Rebecca!
function alterContext(fn, obj) {
return fn.apply(obj,this);
}

如下代码也可以:

function alterContext(fn, obj) {
return fn.call(obj,obj);
}

33、批量改变对象的属性

题目描述

给定一个构造函数 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
function alterObjects(constructor, greeting) {
constructor.prototype.greeting=greeting;
return constructor.greeting;
}

34、属性遍历

题目描述

找出对象 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"]
function iterate(obj) {
var arr=[];
for(var key in obj){
if(obj.hasOwnProperty(key))
{
arr.push(key+": "+obj[key] )
}
}
return arr;
}

35、判断是否包含数字

这时就要用到 正则表达式 了

题目描述

给定字符串 str,检查其是否包含数字,包含返回 true,否则返回 false

输入例子:
containsNumber('abc123')
输出例子:
true
function containsNumber(str) {
var exp=/\d/;
return exp.test(str);
}

36、检查重复字符串

题目描述

给定字符串 str,检查其是否包含连续重复的字母(a-zA-Z),包含返回 true,否则返回 false

输入例子:
containsRepeatingLetter('rattler')
输出例子:
true
function containsRepeatingLetter(str) {
var exp=/([a-zA-Z])\1/;
return exp.test(str);
}

37、判断是否以元音字母结尾

题目描述

给定字符串 str,检查其是否以元音字母结尾 1、元音字母包括 a,e,i,o,u,以及对应的大写 2、包含返回 true,否则返回 false

输入例子:
endsWithVowel('gorilla')
输出例子:
true
function endsWithVowel(str) {
var exp=/[aeiouAEIOU]$/;
return exp.test(str);
}

当然更好的写法是: var exp=/[a,e,i,o,u]$/i;   i 即 ignoreCase 表示忽略大小写。

正则表达式具有三个属性:global、 ignoreCase 、multiline

38、获取指定字符串

题目描述

给定字符串 str,检查其是否包含 3 个连续的数字 1、如果包含,返回最新出现的 3 个数字的字符串 2、如果不包含,返回 false

输入例子:
captureThreeNumbers('9876543')
输出例子:
987

39、判断是否符合指定格式

题目描述

给定字符串 str,检查其是否符合如下格式 1、XXX-XXX-XXXX 2、其中 X 为 Number 类型

输入例子:
matchesPattern('800-555-1212')
输出例子:
true
function matchesPattern(str) {
var exp=/^\d{3}\-\d{3}\-\d{4}$/;
return exp.test(str);
}

40、判断是否符合 USD 格式
【USD 即 United States dollar 美元】

题目描述

给定字符串 str,检查其是否符合美元书写格式 1、以 $ 开始 2、整数部分,从个位起,满 3 个数字用 , 分隔 3、如果为小数,则小数部分长度为 2 4、正确的格式如:$1,023,032.03 或者 $2.03,错误的格式如:$3,432,12.12 或者 $34,344.3

输入例子:
isUSD('$20,933,209.93')
输出例子:
true
function isUSD(str) {
var exp=/^\$([1-9]\d{0,3})(,\d{3})*(\.\d{2})?$/;
return exp.test(str);
}

补:有部分自己没写出来参考了  http://blog.csdn.net/qq_24734285/article/details/50624342  谢谢!!

 
 

#学习笔记#——JavaScript 数组部分编程(七)的更多相关文章

  1. #学习笔记#——JavaScript 数组部分编程(一)

    来自牛客网的js编程题 1.移除数组 arr 中的所有值与 item 相等的元素.不要直接修改数组 arr,结果返回新的数组 function remove(arr, item) { if(!Arra ...

  2. #学习笔记#——JavaScript 数组部分编程(六)

    14. 题目描述 实现一个打点计时器,要求 1.从 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一个数字,每次数字增幅为 1 2.返回的对象中需 ...

  3. #学习笔记#——JavaScript 数组部分编程(五)

    11.为数组 arr 中的每个元素求二次方.不要直接修改数组 arr,结果返回新的数组 function square(arr) { var resultArr=new Array(); for(va ...

  4. #学习笔记#——JavaScript 数组部分编程(四)

    7.合并数组 arr1 和数组 arr2.不要直接修改数组 arr,结果返回新的数组 function concat(arr1, arr2) { return arr1.concat(arr2); } ...

  5. #学习笔记#——JavaScript 数组部分编程(三)

    3.在数组 arr 末尾添加元素 item.不要直接修改数组 arr,结果返回新的数组 主要考察数组的concat方法,代码如下: arr.concat(item); concat 方法不修改原数组. ...

  6. #学习笔记#——JavaScript 数组部分编程(二)

    2.移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回 function removeWithoutCopy(arr, item) { if(!A ...

  7. [前端JS学习笔记]JavaScript 数组

    一.JavaScript数组的奇葩 大多数语言会要求数组的元素是同个类型, 但是JavaScript允许数组元素为多种类型. var arr = ["羽毛球", 666, {&qu ...

  8. [学习笔记]JavaScript之函数式编程

    欢迎指导与讨论:) 前言 函数式编程能使我们的代码结构变得简洁,让代码更接近于自然语言,易于理解. 一.减少不必要的函数嵌套代码 (1)当存在函数嵌套时,若内层函数的参数与外层函数的参数一致时,可以这 ...

  9. JavaScript学习笔记之数组(二)

    JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...

随机推荐

  1. 深入理解JavaScript定时机制

    容易欺骗别人感情的JavaScript定时器 JavaScript的setTimeout与setInterval是两个很容易欺骗别人感情的方法,因为我们开始常常以为调用了就会按既定的方式执行, 我想不 ...

  2. decision tree 决策树(一)

    一 决策树 原理:分类决策树模型是一种描述对实例进行分类的树形结构.决策树由结点(node)和有向边(directed edge)组成.结点有两种类型:内部结点(internal node)和叶结点( ...

  3. [CEOI2007]树的匹配Treasury(树形DP+高精)

    题意 给一棵树,你可以匹配有边相连的两个点,问你这棵树的最大匹配时多少,并且计算出有多少种最大匹配. N≤1000,其中40%的数据答案不超过 108 题解 显然的树形DP+高精. 这题是作为考试题考 ...

  4. [HAOI2006]旅行(并查集)

    寒假填坑五十道省选题——第五道 [HAOI2006]旅行 题目描述 Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N个景点(编号为1,2,3,…,N),这些景点被M条道路 ...

  5. HDU 4862 Jump 费用流

    又是一个看了题解以后还坑了一天的题…… 结果最后发现是抄代码的时候少写了一个负号. 题意: 有一个n*m的网格,其中每个格子上都有0~9的数字.现在你可以玩K次游戏. 一次游戏是这样定义的: 你可以选 ...

  6. gpdb删除segment上残余的session和sql

    转载请注明出处:gpdb删除segment上残余的session和sql 最近公司的gpdb的变卡,导致线上系统查询队列阻塞,用户一点数据都查不出来. 每天早上我和同事都得用我们自家做的gpdb运维平 ...

  7. Qt 5.3 下OpenCV 2.4.11 开发(0)图像处理基本概念

    1.普通情况下的RGB彩色图像:它的每一个像素点都是由三个通道组成,即红色(R).绿色(G)和蓝色(B).8位三通道彩色图像就是每一个像素中每一个通道的取值范围都是 0~255(即二进制下的8位数), ...

  8. zzulioj--1816--矩形(好题数学)

    1816: 矩形 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 88  Solved: 24 SubmitStatusWeb Board Descri ...

  9. ipad无法连接到app store怎么办

    之前入手的air2提示无法连接到app store:你需要首先更新系统到最新的ios版本,去通用设置里面,有个update software, 点击即可,然后才能用apple id 联入,否选择提示连 ...

  10. springMVC No mapping found for HTTP request with URI

    转载自:http://blog.sina.com.cn/s/blog_534f69a00101332u.html 1.问题: No mapping found for HTTP request wit ...