#学习笔记#——JavaScript 数组部分编程(七)
24、柯里化
首先想解释一下,“柯里化”的意思,
【在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术由 Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。】——from 百度百科
题目描述
输入例子:
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、或运算
题目描述
输入例子:
or(false, true)
输出例子:
true
function or(a, b) {
return a||b;
}
26、且运算
题目描述
输入例子:
and(false, true)
输出例子:
false
function and(a, b) {
return a&&b;
}
27、模块
题目描述
function createModule(str1, str2) {
var obj={
greeting :str1,
name :str2,
sayIt :function(){
return this.greeting+', '+this.name ;
}
};
return obj;
}
这里注意下:在连接两个字符的逗号 后面一定要加上空格,即写成这样: ', ' 而不是 ',' 否则就不会是100%通过case。
28、二进制转换
题目描述
输入例子:
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、二进制转换
题目描述
输入例子:
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;
}
题目描述
输入例子:
multiply(3, 0.0001)
输出例子:
0.0003
function multiply(a, b) {
return a*b;
}
32、改变上下文
题目描述
输入例子:
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、批量改变对象的属性
题目描述
输入例子:
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、属性遍历
题目描述
输入例子:
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、判断是否包含数字
这时就要用到 正则表达式 了
题目描述
输入例子:
containsNumber('abc123')
输出例子:
true
function containsNumber(str) {
var exp=/\d/;
return exp.test(str);
}
36、检查重复字符串
题目描述
输入例子:
containsRepeatingLetter('rattler')
输出例子:
true
function containsRepeatingLetter(str) {
var exp=/([a-zA-Z])\1/;
return exp.test(str);
}
37、判断是否以元音字母结尾
题目描述
输入例子:
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、获取指定字符串
题目描述
输入例子:
captureThreeNumbers('9876543')
输出例子:
987
39、判断是否符合指定格式
题目描述
输入例子:
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 美元】
题目描述
输入例子:
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 数组部分编程(七)的更多相关文章
- #学习笔记#——JavaScript 数组部分编程(一)
来自牛客网的js编程题 1.移除数组 arr 中的所有值与 item 相等的元素.不要直接修改数组 arr,结果返回新的数组 function remove(arr, item) { if(!Arra ...
- #学习笔记#——JavaScript 数组部分编程(六)
14. 题目描述 实现一个打点计时器,要求 1.从 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一个数字,每次数字增幅为 1 2.返回的对象中需 ...
- #学习笔记#——JavaScript 数组部分编程(五)
11.为数组 arr 中的每个元素求二次方.不要直接修改数组 arr,结果返回新的数组 function square(arr) { var resultArr=new Array(); for(va ...
- #学习笔记#——JavaScript 数组部分编程(四)
7.合并数组 arr1 和数组 arr2.不要直接修改数组 arr,结果返回新的数组 function concat(arr1, arr2) { return arr1.concat(arr2); } ...
- #学习笔记#——JavaScript 数组部分编程(三)
3.在数组 arr 末尾添加元素 item.不要直接修改数组 arr,结果返回新的数组 主要考察数组的concat方法,代码如下: arr.concat(item); concat 方法不修改原数组. ...
- #学习笔记#——JavaScript 数组部分编程(二)
2.移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回 function removeWithoutCopy(arr, item) { if(!A ...
- [前端JS学习笔记]JavaScript 数组
一.JavaScript数组的奇葩 大多数语言会要求数组的元素是同个类型, 但是JavaScript允许数组元素为多种类型. var arr = ["羽毛球", 666, {&qu ...
- [学习笔记]JavaScript之函数式编程
欢迎指导与讨论:) 前言 函数式编程能使我们的代码结构变得简洁,让代码更接近于自然语言,易于理解. 一.减少不必要的函数嵌套代码 (1)当存在函数嵌套时,若内层函数的参数与外层函数的参数一致时,可以这 ...
- JavaScript学习笔记之数组(二)
JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...
随机推荐
- global_step
global_step=tf.Variable(0, trainable=False) 设定trainable=False 可以防止该变量被数据流图的 GraphKeys.TRAINABLE_VARI ...
- SPOJ8222 NSUBSTR - Substrings 后缀自动机_动态规划
讲起来不是特别好讲.总之,如果 $dp[i+1]>=dp[i]$,故$dp[i]=max(dp[i],dp[i+1])$ Code: #include <cstdio> #inclu ...
- js实现观察者模式风格替换
如下图,我们看到两种风格:在选择男士时,页面颜色为黑色:在选择女士时,页面颜色为粉红色. 主要可以分为两类: 下拉框 ---> 被观察者 div ---> 观察者 面向过程实现风格替换: ...
- [转] -- html5手机网站自适应需要加的meta标签
webapp开发初期,会碰到在pc端开发好的页面在移动端显示过大的问题,这里需要在html head中加入meta标签来控制缩放 <meta name=" viewport" ...
- 用树链剖分来写LCA
当两个点在一条链上,它们的LCA就是深度较小的那个点. 于是这种树链剖分写LCA的思想就是把要求的两个点想办法靠到一条链上. 而且要靠到尽量更优的一条链上(重链). 做法: 预处理出每棵树上的重链(s ...
- HDU-2050 折线分割平面 找规律&递推
题目链接:https://cn.vjudge.net/problem/HDU-2050 题意 算了吧,中文题不解释了 我们看到过很多直线分割平面的题目,今天的这个题目稍微有些变化,我们要求的是n条折线 ...
- [JSOI2007]文本生成器(AC自动机+DP)
题意 给你n个串.问有多少长度为m的串使得这n个串至少在其中出现过一次.输出答案膜10007意义下的结果. (n<=100,每个串的长度<=100) 题解 在AC自动机上跑DP. 用到一个 ...
- python -迭代器与生成器 以及 iterable(可迭代对象)、yield语句
我刚开始学习编程没多久,对于很多知识还完全不知道,而有些知道的也是一知半解,我想把学习到的知识记录下来,一是弥补记忆力差的毛病,二也是为了待以后知识能进一步理解透彻时再回来做一个补充. 参考链接: 完 ...
- Unity 编辑器学习(三)之 Light & Baked
上一篇博客已经详细的介绍GI了,接下来我们讲点实际的,怎么烘焙场景及注意事项. 一.Light Property: Function: Type 当前灯光的类型.有四种类型:Directional, ...
- C# 快捷使用自定义配置节点
C#除了appSettings和connectionStrings默认配置外还允许用户自定义使用配置.C# 提供3中简单的自定义配置,配置文件如下 <?xml version="1.0 ...