看湯姆大叔的博文,其中有篇(猛戳這里)的最后有6道編程題,於是我也試試,大家都可以先試試。
1、找出數字數組中最大的元素(使用Math.max函數)
var a = [1, 2, 3, 6, 5, 4]; var ans = Math.max.apply(null, a); console.log(ans); // 6
這題很巧妙地用了apply,如果不是數組,是很多數字求最大值,我們知道可以這樣:
var ans = Math.max(1, 2, 3, 4, 5, 6); console.log(ans); // 6
而apply的第二個參數正是一個數組,都不用進行轉換了。
還有一種用eval+toString的實現:
var a = [1, 2, 3, 6, 5, 4]; var ans = eval( 'Math.max(' + a.toString() + ')'); console.log(ans); // 6
(2017.03.02 add)學習了 ES6 后,我們有了更簡單的方法:
let a = [1, 2, 3, 6, 5, 4]; let maxn = Math.max(...a); console.log(maxn); // 6
2、轉化一個數字數組為function數組(每個function都彈出相應的數字)
var a = [1, 2, 3, 4, 5, 6]; var len = a.length; for(var i = 0; i < len; i++) { var num = a[i]; (function(num) { var f = function() { console.log(num); }; a[i] = f; })(num); } for(var i = 0; i < len; i++) a[i](); // 1 // 2 // 3 // 4 // 5 // 6
我覺得這跟給n個a標簽,彈出相應標簽對應的編號是一個類型的題,用閉包保存變量到內存即可。
3、給object數組進行排序(排序條件是每個元素對象的屬性個數)
var a = { name: 'hanzichi', age: 10, location: 'china' }; var b = { name: 'curry' }; var c = { name: 'kobe', sex: 'male' }; Object.prototype.getLength = function() { var num = 0; for(var key in this) { if(this.hasOwnProperty(key)) num++; } return num; }; var arr = [a, b, c]; arr.sort(function(a, b) { return a.getLength() > b.getLength(); }); console.log(arr);
這題不難,數組排序,當然是sort,排序條件是對象的屬性個數,可以寫個函數計算,注意可能要用hasOwnProperty判斷下。
4、利用JavaScript打印出Fibonacci數(不使用全局變量)
(function(a, b) { var c = a + b; console.log(c); if(c > 100) return; arguments.callee(b, c); })(-1, 1);
這題沒看明白,是打出斐波那契數列的前n項么?還是第n項...
function fn(n) { var a = []; a[0] = 0, a[1] = 1; for(var i = 2; i < n; i++) a[i] = a[i - 1] + a[i - 2]; for(var i = 0; i < n; i++) console.log(a[i]); } fn(5); // 10表示需要的斐波那契數列個數 // 0 // 1 // 1 // 2 // 3
不使用全局變量,我把它們寫在函數里了應該算是局部變量了吧,難道這樣就好了?你怎么看?
(2017.03.02 add)學習了 ES6 后,我們可以用 generator 更好地打印菲波那切數列。
// print the first n fib number function* fib(n) { let [a, b] = [0, 1]; while (n--) { yield a; [a, b] = [b, a + b] } } for (let item of fib(5)) console.log(item); // 0 // 1 // 1 // 2 // 3
5、實現如下語法的功能:var a = (5).plus(3).minus(6); //2
Number.prototype.plus = function(a) { return this + a; }; Number.prototype.minus = function(a) { return this - a; }; var a = (5).plus(3).minus(6); console.log(a); // 2
直接在Number對象上加擴展方法即可,傳說中這樣很不好,but我也想不到更好的辦法了...
6、實現如下語法的功能:var a = add(2)(3)(4); //9
function add(a) { var temp = function(b) { return add(a + b); } temp.valueOf = temp.toString = function() { return a; }; return temp; } var ans = add(2)(3)(4); console.log(ans); // 9
對valueOf和toString的考察,具體可以參考《valueOf和toString》
另看到一種很飄逸的寫法(來自Gaubee):
function add(num){ num += ~~add; add.num = num; return add; } add.valueOf = add.toString = function(){return add.num}; var ans = add(3)(4)(5)(6); // 18 alert(ans);
(2017.03.07 add)補充個 ES6 解法:
let add = (...a) => { let helper = (...b) => { return add(...[...a, ...b]); }; helper.toString = helper.valueOf = () => { let sum = 0; for (let item of a) sum += item; return sum; }; return helper; }; alert(add(1)(2)) // 3 alert(add(1, 2, 3)(10)) // 16 alert(add(1)(2)(3)(4)(5)) // 15 alert(add(1)(2, 3)(4, 5)) // 15
大家有什么意見建議的歡迎交流指導~