introduction
J'ai une pièce pleine de miroirs magiques . Ce sont des artefacts mystérieux qui peuvent reproduire n'importe quel élément, à l'exception d'un autre miroir magique. Plus explicitement, une version en double de l'élément apparaîtra de l'autre côté du miroir, à la même distance. Cependant, s'il y a un autre miroir magique sur le chemin de chaque côté, entre le miroir de duplication et l'un ou l'autre élément (original ou dupliqué), le doublon n'est pas formé. L'article d'origine peut être à gauche ou à droite du miroir, et le duplicata apparaîtra de l'autre côté. De plus, l'élément en double peut lui-même être dupliqué par un autre miroir. Les éléments ne bloquent jamais la duplication d'autres éléments (sauf en étant directement sur la position du double potentiel).
Contribution
Votre entrée est une chaîne composée des caractères .#|
, qui représentent un espace vide, des objets et des miroirs magiques. Il y aura toujours au moins un miroir magique dans l'entrée.
Sortie
Votre sortie doit être une autre chaîne où chaque miroir magique a dupliqué chaque élément qu'il peut, selon les règles ci-dessus. Vous pouvez supposer qu'il y aura toujours un espace vide à l'endroit où un élément en double apparaît (afin qu'ils ne sortent pas des limites).
Exemples
Considérez la chaîne d'entrée
.#.|.....|......#
A B C D
où nous avons marqué certaines positions pour plus de clarté. Le miroir B
duplique l'article A
, qui se termine à sa droite:
.#.|.#...|......#
A B C D
Miroir C
duplique ensuite le nouvel élément:
.#.|.#...|...#..#
A B C D
Le miroir C
ne peut pas dupliquer l'élément A
, car le miroir B
est sur le chemin. Il ne peut pas non plus dupliquer l'élément D
, car le miroir B
est sur le chemin de l'autre côté. De même, le miroir B
ne peut pas dupliquer l'élément D
ou le doublon à côté, car le miroir C
est sur le chemin, c'est donc la sortie correcte.
Pour un autre exemple, considérons l'entrée
.##..#...|#..##...|..##....#.
AB C DE FG H IJ K
Le miroir D
peut être dupliqué A
et B
à droite, E
et G
à gauche.
C
et F
sont déjà des doublons les uns des autres. La chaîne devient
.##.##..#|#..##.##|..##....#.
AB C DE FG H IJ K
Mirror H
peut dupliquer E
, F
et les doublons de A
et B
vers la droite et I
vers la gauche.
G
et J
sont déjà des doublons les uns des autres, et le miroir D
est sur le chemin de K
. Maintenant nous avons
.##.##..#|#..#####|#####..##.
AB C DE FG H IJ K
Enfin, le miroir D
peut dupliquer le doublon de I
vers la gauche. On se retrouve avec
.#####..#|#..#####|#####..##.
AB C DE FG H IJ K
Règles et notation
Vous pouvez écrire soit un programme complet soit une fonction. Le nombre d'octets le plus bas gagne. Les soumissions qui n'utilisent pas de moteurs d'expression régulière sont en concurrence distincte de celles qui le font et peuvent être marquées d'un (pas d'expression régulière) .
Cas de test
"|" -> "|"
"..|.." -> "..|.."
".#.|..." -> ".#.|.#."
"..#|.#." -> ".##|##."
".#..|....|.." -> ".#..|..#.|.#"
".|..|.#....." -> "#|#.|.#....."
"...|.#...|....#" -> ".##|##...|...##"
"......#|......." -> "......#|#......"
".#.|.....|......#" -> ".#.|.#...|...#..#"
".......|...#.##|...." -> "##.#...|...#.##|##.#"
"...#..||.......#..#...#" -> "...#..||.......#..#...#"
".##|.#....||#||......#|.#" -> ".##|##....||#||.....##|##"
".##..#...|#..##...|..##....#." -> ".#####..#|#..#####|#####..##."
".#|...||...|#...|..##...|#...." -> ".#|#..||.##|##..|..##..#|#..##"
"....#.|...#.|..|.|.....|..#......" -> "..#.#.|.#.#.|.#|#|#.#..|..#.#...."
"..|....|.....#.|.....|...|.#.|..|.|...#......" -> ".#|#...|...#.#.|.#.#.|.#.|.#.|.#|#|#..#......"
Réponses:
Rétine , 50 octets
Essayez-le en ligne! (La première ligne active une suite de tests séparés par un saut de ligne.)
Je suppose que c'est l'opposé d'une soumission (sans regex).
Explication
Il s'agit simplement d'une substitution d'expression régulière, qui est appliquée à plusieurs reprises (
+
) jusqu'à ce que la chaîne cesse de changer. J'utilise des groupes d'équilibrage pour m'assurer que les deux positions en miroir sont à la même distance du miroir donné (les références inverses ne le feront pas, car la chaîne exacte des deux côtés de la|
peut être différente).Il est remplacé par
#$2#
ce qui remplace simplement le premier et le dernier caractère du match par un#
.la source
Perl, 49 octets
Un crédit complet à @Martin Ender pour celui qui a suggéré cette expression régulière 15 octets plus courte que la mienne.
47 octets de code +
-pl
drapeauxPour l'exécuter:
Les première (
([.#])
) et dernière ((?!\1)[^|]
) parties sont les mêmes que dans la réponse Retina (voir l'explication là-bas).La partie centrale (
(\||[^|](?2)[^|])
) utilise perl recursion ((?2)
) pour faire correspondre un miroir (\|
) ou (|
) deux non-mirrors-characters ([^|]
) séparés par le même motif ((?2)
).Ma version plus ancienne (et plus laide):
s/([.#])(([^|]*)\|(??{$3=~s%.%[^|]%gr}))(?!\1)[^|]/#$2#/&&redo
la source
Haskell (pas d'expression régulière), 117 octets
la source
PHP,
123117100 octetsle programme prend l'argument de la ligne de commande, l'expression régulière extraite de @Martin Ender / Dada. Courez avec
-r
.la source
C, 176 octets
Non golfé
la source
'#'
et'.'
par35
et46
respectivement.x,i,j;void t(char*a){while(a[i]++)if(a[i]=='|'){for(j=x;a[j++]&&j<=i*2-x;j++){if((a[j]==35)&&(a[2*i-j]==46)){a[2*i-j]=35;i=-1;break;}if((i-j)&&(a[j]=='|'))break;}x=i+1;}}
- 170 octetsJavaScript (ES6), 170 octets
Non golfé:
la source