函式的柯里化

2021-09-26 15:21:53 字數 712 閱讀 6950

問題描述:已知 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 的呼叫引數

函式柯里化基本是在做這麼一件事情:只傳遞給函式一部分引數來呼叫它,讓它返回乙個函式去處理剩下的引數。用公式表示就是我們要做的事情其實是

fn(a,b,c,d)=>fn(a)(c)(d);

fn(a,b,c,d)=>fn(a,b)(c)(d);

fn(a,b,c,d)=>fn(a)(b,c,d);

再或者這樣:

fn(a,b,c,d)=>fn(a)(b)(c)(d)();

fn(a,b,c,d)=>fn(a);fn(b);fn(c);fn(d);fn();

function curryit(fn) 

}

實現方法二:

function curryit(fn) 

return result;

}

函式柯里化

在電腦科學中,柯里化 currying 是把接受多個引數的函式變換成接受乙個單一引數 最初函式的第乙個引數 的函式,並且返回接受餘下的引數且返回結果的新函式的技術。在直覺上,柯里化聲稱 如果你固定某些引數,你將得到接受餘下引數的乙個函式 柯里化實現的原理 在函式式程式語言中,將函式可以當做物件傳遞呼...

函式柯里化

curry 的概念 只傳遞給函式一部分引數來呼叫它,讓它返回乙個函式去處理剩下的引數先看乙個簡單例子,add函式接受 2 個引數 或者多個 addx函式接受 1 個引數。換而言之,所謂 柯里化 就是把乙個多引數的函式,轉化為單引數函式。將乙個函式轉換為乙個新的函式 非柯里化 function add...

函式柯里化

curry 的概念 只傳遞給函式一部分引數來呼叫它,讓它返回乙個函式去處理剩下的引數先看乙個簡單例子,add函式接受 2 個引數 或者多個 addx函式接受 1 個引數。換而言之,所謂 柯里化 就是把乙個多引數的函式,轉化為單引數函式。將乙個函式轉換為乙個新的函式 非柯里化 function add...