Chaînes avec contexte
Pour les besoins de ce défi, une chaîne avec contexte est un triple de chaînes, appelé le contexte gauche , la partie données et le contexte droit . Il représente une sous-chaîne d'une chaîne plus longue. Nous utilisons le tuyau vertical |
comme séparateur, donc un exemple de chaîne avec contexte est cod|e-go|lf
, où le contexte gauche est cod
, les données sont e-go
et le contexte droit est lf
. Cet exemple représente la sous-chaîne e-go
de code-golf
.
Maintenant, pour concaténer deux chaînes avec le contexte, nous procédons comme suit, en utilisant aa|bcc|dee
et cc|de|eee
comme exemples. On aligne les cordes comme dans le schéma
a a|b c c|d e e
c c|d e|e e e
de sorte que leurs parties de données sont adjacentes. La partie données de la concaténation est la concaténation des parties données, dans ce cas bccde
. Dans ce cas, le contexte de gauche est la partie qui étend le plus à gauche de la première partie de données aa
. De même, le bon contexte est eee
, donc la concaténation est la chaîne avec le contexte aa|bccde|eee
. Pour un deuxième exemple, considérons a|bb|cd
et aabb|cd|
, où le deuxième mot a un contexte de droite vide. Le diagramme d'alignement est
a|b b|c d
a a b b|c d|
où le contexte gauche du deuxième mot s'étend plus loin que celui du premier. La concaténation est aa|bbcd|
.
Mais attendez, il y a un piège: si les lettres du diagramme d'alignement ne correspondent pas, la concaténation n'existe pas! Par exemple, le diagramme de aa|bb|cc
et c|c|c
est
a a|b b|c c
c|c|c
où le b
et c
sur la quatrième colonne ne sont pas d'accord, ils ne peuvent donc pas être concaténés.
La tâche
Votre travail consiste à écrire un programme qui prend en deux chaînes avec un contexte dont les parties sont séparées par |
comme ci-dessus, et génère leur concaténation si elle existe, et autre chose sinon. "Quelque chose d'autre" peut être n'importe quelle valeur, y compris aucune sortie, tant que ce n'est pas une chaîne valide avec contexte, et c'est la même chose dans tous les cas. Cependant, le lancement d'une erreur n'est pas acceptable. Vous pouvez donner un programme STDIN à STDOUT ou une fonction, et les fonctions anonymes sont également acceptées. Le plus petit nombre d'octets gagne et les failles standard sont interdites.
Cas de test
aa|bcc|dee cc|de|eee -> aa|bccde|eee
a|bb|cd aabb|cd| -> aa|bbcd|
a|b|cccd aab|cc|c -> aa|bcc|cd
a|b|c b||cd -> a|b|cd
aa|bb|cc c|c|c -> None
aaa|b|c abb|cd|d -> None
|bb|cd abb|c|ed -> None
a|b|c a||cd -> None
|1<2=""
à la définition de&
devrait résoudre ce problème. Je suis désolé de ne pas l'avoir spécifié plus explicitement dans les spécifications, je vais le modifier.