#学习笔记#——JavaScript 数组部分编程(七)

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  谢谢!!

时间: 08-10

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

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

一.JavaScript数组的奇葩 大多数语言会要求数组的元素是同个类型, 但是JavaScript允许数组元素为多种类型. var arr = ["羽毛球", 666, {"json:":"666"}]; console.log(arr.length); 二.JavaScript 数组的两种声明 1.var arr = [元素]; var arr = ["坚持"]; 2.new Array(); 或者 var arr2 =

Linux 程序设计学习笔记----终端及串口编程基础之概念详解

转载请注明出处,谢谢! linux下的终端及串口的相关概念有: tty,控制台,虚拟终端,串口,console(控制台终端)详解 部分内容整理于网络. 终端/控制台 终端和控制台都不是个人电脑的概念,而是多人共用的小型中型大型计算机上的概念. 1.终端 一台主机,连很多终端,终端为主机提供了人机接口,每个人都通过终端使用主机的资源. 终端有字符哑终端和图形终端两种. 控制台是另一种人机接口, 不通过终端与主机相连, 而是通过显示卡-显示器和键盘接口分别与主机相连, 这是人控制主机的第一人机接口.

C和指针 学习笔记-3.数组与指针

数据名代表首地址 指向数组的指针 #include <stdio.h> extern void iterate(int *p); void main(){ int a[]={1,2,3,4,5}; iterate(a); } void iterate(int *p){ int i; for(i=0;i<5;i++){ printf("%d",*p++); } } 指向一维数组的指针 int (*p)[3] #include <stdio.h> void i

学习笔记---Javascript事件Event、IE浏览器下的拖拽效果

学习笔记---Javascript事件Event.IE浏览器下的拖拽效果     1. 关于event常用属性有returnValue(是否允许事件处理继续进行, false为停止继续操作).srcElement(触发事件的事件源对象)和attachEvent("onclick",function(){...}); 2. a. 实现拖放(Drag and Drop): 目前支支持IE, 若定制某对象为可拖放对象, 则必须覆盖目标对象的dragenter和dragover事件, 可以用e

Sharepoint2013搜索学习笔记之自定义结果源(七)

搜索中心新建好之后在搜索结果页上会默认有所有内容,人员,对话,视频这四个结果分类,每个分类会返回指定范围的搜索结果,这里我再添加了部门日志结果分类,搜索这个分类只会返回部门日志内容类型的搜索结果,要实现这个效果,步骤如下: 第一步,进入管理中心,进入管理应用程序,点击Search Service 应用程序,进入搜索管理页,再点击结果源如图: 第二步,新建结果源,填写名称,协议填写本地sharepoint,凭据信息选择默认, 第三步,点击启动查询生成器,生成查询语句,最后点保存,接着继续点新建内容

Linux 程序设计学习笔记----终端及串口编程及实例应用

转载请注明出处,http://blog.csdn.net/suool/article/details/38385355. 部分内容类源于网络. 终端属性详解及设置 属性 为了控制终端正常工作,终端的属性包括输入属性.输出属性.控制属性.本地属性.线路规程属性以及控制字符. 其在系统源代码的termios.h中定义(具体的说明文档http://pubs.opengroup.org/onlinepubs/7908799/xsh/termios.h.html),其结构体成员主要是 Thetermios

Swift学习笔记(12)--数组和字典的复制

Swift中,数组Array和字典Dictionary是用结构来实现的,但是数组与字典和其它结构在进行赋值或者作为参数传递给函数的时候有一些不同. 并且数组和字典的这些操作,又与Foundation中的NSArray和NSDictionary不同,它们是用类来实现的. 注意:下面的小节将会介绍数组,字典,字符串等的复制操作.这些复制操作看起来都已经发生,但是Swift只会在确实需要复制的时候才会完整复制,从而达到最优的性能. 字典的赋值和复制操作 每次将一个字典Dictionary类型赋值给一个

转 网络编程学习笔记一:Socket编程

网络编程学习笔记一:Socket编程 “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览器浏览网页时,浏览器的进程怎么与web服务器通信的?当你用QQ聊天时,QQ进程怎么与服务器或你好友所在的QQ进程通信?这些都得靠socket?那什么是socket?socket的类型有哪些?还有socket的基本函数,这些都是本文想介绍的.本文的主要内容如下:

Swift学习笔记(5)--数组

数组的下标从0开始计数,相关方法属性涉及到下标时也从0开始计数 1.定义: //1.可变数组 var cityArray = ["Portland","San Francisco","Cupertino"] //2.不可变数组 let cityArray2 = ["Portland","San Francisco","Beijing"] //3.空数组 var animalArray =