次のコードがあります。
import operator
def stagger(l, w):
if len(l)>=w:
return [tuple(l[0:w])]+stagger(l[1:], w)
return []
def pleat(f, l, w=2):
return map(lambda p: f(*p), stagger(l, w))
if __name__=="__main__":
print pleat(operator.add, range(10))
print pleat(lambda x, y, z: x*y/z, range(3, 13), 3)
print pleat(lambda x: "~%s~"%(x), range(10), 1)
print pleat(lambda a, b, x, y: a+b==x+y, [3, 2, 4, 1, 5, 0, 9, 9, 0], 4)
重要な部分: Pleat は任意の関数と任意のシーケンスを取り、そのシーケンスの最初の一握りの要素をパラメーターとして受け取った関数に渡します。
Haskellでこれを行う方法はありますか、それとも私は夢を見ていますか?