Étant un hacker Haskell, je préfère la notation sans point à celle avec point. Malheureusement, certaines personnes trouvent la notation sans point difficile à lire, et j'ai du mal à obtenir le nombre correct de parenthèses lorsque j'écris en pointant. Aidez-moi à convertir du code écrit en pointfree en notation pointue!
À propos de
En notation sans point, nous utilisons des points (oui, vraiment) pour alimenter la sortie d'une fonction dans une autre. Disons, si vous aviez une fonction succ
qui prend un nombre et y ajoute 1, et que vous vouliez créer une fonction qui ajoute 3 à un nombre, au lieu de faire ceci:
\x -> succ(succ(succ(x)))
vous pourriez faire ceci:
succ.succ.succ
Pointfree ne fonctionne cependant qu'avec des fonctions qui prennent un seul paramètre (dans ce défi de toute façon), donc si notre fonction ne l'était pas succ
mais plutôt add
qui prend 2 nombres et les additionne, nous devrions lui fournir des arguments jusqu'à ce qu'il n'en reste plus qu'un:
pointful: \x -> add 1(add 1(add 1 x))
pointfree: add 1 . add 1 . add 1
Enfin, les fonctions peuvent prendre d'autres fonctions comme arguments:
Pointfree: map (f a . f b) . id
Pointful: \x -> map (\x -> f a (f b x)) (id x)
Javascript equivalent: x => map (x => f(a,f(b,x)), id(x))
Entrée et sortie attendue
f . f . f
\x -> f (f (f x))
f a . f b . f c
\x -> f a (f b (f c x))
f (f a . f b) . f c
\x -> f (\x -> f a (f b x)) (f c x)
a b c . d e . f g h i . j k l . m
\x -> a b c (d e (f g h i (j k l (m x))))
a.b(c.d)e.f g(h)(i j.k).l(m(n.o).p)
\x->a(b(\y->c(d y))e(f g h(\z->i j(k z))(l(\q->m(\w->n(o w))(p q))x)))
Règles
- Votre sortie peut avoir plus d'espaces ou de parenthèses que nécessaire, tant qu'ils sont équilibrés
- Vous n'avez pas à vous assurer que le nom de la variable que vous créez
\x
n'est pas déjà utilisé ailleurs dans le code - A vous de choisir de créer une fonction ou un programme complet
- C'est
codegolf
, le code le plus court en octets gagne!
Vous trouverez peut-être contondant utile, il convertit entre les deux notations (mais factorise également le code lorsque cela est possible): https://blunt.herokuapp.com
(+).(*3)
c'est la même chose que\x y->3*x+y
(.).(.)
qui se convertit en\i b c f -> i (b c f)
.
par un (
, \x
ajouter un et ajouter un correspondant x
et autant )
que nécessaire? Ou est-ce plus compliqué que ça?
\ d->f(\k->f(f d k))
, mais vous pouvez supposer que tous les points sont alimentés par deux arguments dans ce défi