Rotonyme 2
Ein "Rotonym" ist ein Wort, das ROT13 in ein anderes Wort (in derselben Sprache) umwandelt.
Für diese Herausforderung verwenden wir eine alternative Definition: Ein "Rotonym" ist ein Wort, das sich kreisförmig in ein anderes Wort (in derselben Sprache) verschiebt.
Beispielsweise:
'stable' < 'tables' < 'ablest'
'abort' > 'tabor'
'tada' >> 'data'
Die Herausforderung
Schreiben Sie ein Programm oder eine Funktion, die eine Wörterbuch- / Wortliste akzeptiert und eine vollständige Liste von Rotonymen druckt oder zurückgibt.
- Ordnung spielt keine Rolle.
- Bei Vergleichen sollte die Groß- und Kleinschreibung nicht berücksichtigt werden. Sie können also davon ausgehen, dass die Eingabe als Wörterbuch nur in Kleinbuchstaben übergeben wird.
- Das Ergebnis sollte als einzelne Wörter (nicht als Paare) ausgedrückt werden und keine Duplikate enthalten. Sie können also davon ausgehen, dass die Eingabe keine Duplikate enthält.
- Das ist Code-Golf .
Beispiel
Gegeben
ablest
abort
green
irk
stable
tables
tabor
tata
terra
vex
you
Rückkehr
ablest
abort
stable
tables
tabor
Ein echter Test
Gegeben
a aa aal aalii aam aani aardvark aardwolf aaron aaronic aaronical aaronite aaronitic aaru ab aba ababdeh ababua abac abaca abacate abacay abacinate abacination abaciscus abacist aback abactinal abactinally abaction abactor abaculus abacus abadite abaff abaft abaisance abaiser abaissed abalienate abalienation abalone abama abampere abandon abandonable abandoned abandonedly abandonee abandoner abandonment abanic abantes abaptiston abarambo abaris abarthrosis abarticular abarticulation abas abase abased abasedly abasedness abasement abaser abasgi abash abashed abashedly abashedness abashless abashlessly abashment abasia abasic abask abassin abastardize abatable abate abatement abater abatis abatised abaton abator abattoir abatua abature abave abaxial abaxile abaze abb abba abbacomes abbacy abbadide abbas abbasi abbassi abbasside abbatial abbatical abbess abbey abbeystede abbie abbot abbotcy abbotnullius abbotship abbreviate abbreviately abbreviation abbreviator abbreviatory abbreviature abby abcoulomb abdal abdat abderian abderite abdest abdicable abdicant abdicate abdication abdicative abdicator abdiel abditive abditory abdomen abdominal abdominales abdominalian abdominally abdominoanterior abdominocardiac abdominocentesis abdominocystic abdominogenital abdominohysterectomy abdominohysterotomy abdominoposterior abdominoscope abdominoscopy abdominothoracic abdominous abdominovaginal abdominovesical abduce abducens abducent abduct abduction abductor abe abeam abear abearance abecedarian abecedarium abecedary abed abeigh abel abele abelia abelian abelicea abelite abelmoschus abelmosk abelonian abeltree abencerrages abenteric abepithymia aberdeen aberdevine aberdonian aberia aberrance aberrancy aberrant aberrate aberration aberrational aberrator aberrometer aberroscope aberuncator abet abetment ablest abort abut ach ache acher achete achill achor acor acre acyl ad adad adat add addlings adet ala ama baa bafta balonea batea beta caba cha chilla cora crea da dad dada data each lacy orach rache saddling stable tables tabor tabu tade teache zoquean zoraptera zorgite zoril zorilla zorillinae zorillo zoroastrian zoroastrianism zoroastrism zorotypus zorrillo zorro zosma zoster zostera zosteraceae zosteriform zosteropinae zosterops zouave zounds zowie zoysia zubeneschamali zuccarino zucchetto zucchini zudda zugtierlast zugtierlaster zuisin zuleika zulhijjah zulinde zulkadah zulu zuludom zuluize zumatic zumbooruk zuni zunian zunyite zupanate zutugil zuurveldt zuza zwanziger zwieback zwinglian zwinglianism zwinglianist zwitter zwitterion zwitterionic zyga zygadenine zygadenus zygaena zygaenid zygaenidae zygal zygantra zygantrum zygapophyseal zygapophysis zygion zygite zygnema zygnemaceae zygnemales zygnemataceae zygnemataceous zygnematales zygobranch zygobranchia zygobranchiata zygobranchiate zygocactus zygodactyl zygodactylae zygodactyli zygodactylic zygodactylism zygodactylous zygodont zygolabialis zygoma zygomata zygomatic zygomaticoauricular zygomaticoauricularis zygomaticofacial zygomaticofrontal zygomaticomaxillary zygomaticoorbital zygomaticosphenoid zygomaticotemporal zygomaticum zygomaticus zygomaxillare zygomaxillary zygomorphic zygomorphism zygomorphous zygomycete zygomycetes zygomycetous zygon zygoneure zygophore zygophoric zygophyceae zygophyceous zygophyllaceae zygophyllaceous zygophyllum zygophyte zygopleural zygoptera zygopteraceae zygopteran zygopterid zygopterides zygopteris zygopteron zygopterous zygosaccharomyces zygose zygosis zygosperm zygosphenal zygosphene zygosphere zygosporange zygosporangium zygospore zygosporic zygosporophore zygostyle zygotactic zygotaxis zygote zygotene zygotic zygotoblast zygotoid zygotomere zygous zygozoospore zymase zyme zymic zymin zymite zymogen zymogene zymogenesis zymogenic zymogenous zymoid zymologic zymological zymologist zymology zymolyis zymolysis zymolytic zymome zymometer zymomin zymophore zymophoric zymophosphate zymophyte zymoplastic zymoscope zymosimeter zymosis zymosterol zymosthenic zymotechnic zymotechnical zymotechnics zymotechny zymotic zymotically zymotize zymotoxic zymurgy zyrenian zyrian zyryan zythem zythia zythum zyzomys zyzzogeton
Rückkehr
aal aam aba abac abaft abalone abate abet ablest abort abut ach ache acher achete achill achor acor acre acyl ad adad adat add addlings adet ala ama baa bafta balonea batea beta caba cha chilla cora crea da dad dada data each lacy orach rache saddling stable tables tabor tabu tade teache
abdominovaginal
Du hast da ein paar seltsame Worte.Antworten:
Gelee , 8 Bytes
Probieren Sie es online aus!
Alternative Version, 7 Bytes
Dyadic hat
Ƭ
früher etwas Seltsames gemacht, also hat das nicht funktioniert, als die Herausforderung veröffentlicht wurde.Probieren Sie es online aus!
Wie es funktioniert
quelle
ṙ1$ÐĿfḊɗÐf
.APL (Dyalog) , 20 Bytes
Benötigt
⎕io←0
Probieren Sie es online aus!
(1↓∘∪⍳∘≢⌽¨⊂)¨
Ruft die eindeutigen Rotationen (ohne die Zeichenfolge selbst) jeder Zeichenfolge im Wörterbuch ab≢
nimmt die Länge eines Vektors⍳∘≢
Erstellt den Bereich von 0 bis zur Länge⌽
dreht einen Vektor einige Male, z. B. 2⌽'abort '->' ortab '⍳∘≢⌽¨⊂
gibt dann alle Umdrehungen eines Vektors an∪
entfernt die Duplikate1↓
entfernt das erste Element (die ursprüngliche Zeichenfolge),/
glättet alle Rotationen in einer Liste⊂∩¨
nimmt den Schnittpunkt des Wörterbuchs mit den Rotationenquelle
⊂∩¨
Trick (oder umgekehrt) für einen weiteren -1APL (Dyalog Unicode) ,
2523221716 Byte SBCSLeiht Ideen aus der ngn / k-Lösung von ngn aus . Und dann -6 danke an ihn. Auch -1 durch Rückgabe einer beiliegenden Liste wie H.PWiz .
Anonyme stillschweigende Präfixfunktion.
Probieren Sie es online aus!
(
…)¨
Wenden Sie auf jedes Wort die folgende stillschweigende Funktion an:,⍨
verketten Sie das Wort zu sich selbst≢,/
alle wortlangen Unterzeichenfolgen (dh alle Rotationen)∪
einzigartige Elemente dieser Rotationen (um zu verhindern, dass Wörter wietata
zweimal erscheinen)1,.↓
die Verkettung der Drop-Firsts (der ursprünglichen Wörter) jeder Liste⊂∩¨
Schnittpunkt des Inhalts dieser und der gesamten ursprünglichen WortlisteAlte Lösung
-2 danke an ngn.
Anonymes Präfix Lambda.
Probieren Sie es online aus!
{
…}
Funktion wo⍵
ist die Wortliste:(
…)¨
Wenden Sie auf jedes Wort die folgende stillschweigende Funktion an:,⍨
verketten Sie das Wort zu sich selbst≢,/
alle wortlangen Unterzeichenfolgen (dh alle Rotationen)∪
einzigartige Elemente dieser Rotationen (um zu verhindern, dass Wörter wietata
zweimal erscheinen)↑
Mischen Sie die Liste der Listen in einer einzigen Matrix (Pads mit All-Space-Strings).⍵∊⍨
Geben Sie an, welche Elemente der Matrix Mitglieder der ursprünglichen Liste sind+/
Summiere die Zeilen (zählt das Vorkommen jedes der ursprünglichen Wörter)2≤
Geben Sie an, welche Duplikate haben (dh nicht anders als beim Zurückdrehen zum Original).⍵/⍨
Verwenden Sie dies, um die ursprüngliche Liste zu filternquelle
{∪⌽∘⍵¨⍳≢⍵}
->(∪≢,/,⍨)
; Ihre Verwendung von∊
ist klug{⍵∩⊃,/1↓¨(∪≢,/,⍨)¨⍵}
⊢∩∘⊃1,.↓(∪≢,/,⍨)¨
Brachylog , 26 Bytes
Probieren Sie es online aus!
quelle
Python 2 ,
736967 BytesProbieren Sie es online aus!
Nimmt eine Reihe von Wörtern (Kleinbuchstaben) und gibt eine Liste von Rotonymen zurück.
Gerettet
quelle
K (ngn / k) , 23 Bytes
Probieren Sie es online aus!
{
}
ist eine Funktion mit Argumentx
0 1_
schneidet eine Zeichenfolge bei den Indizes 0 und 1, z. B."abcd"
->(,"a";"bcd")
|
kehrt die beiden Scheiben um:("bcd";,"a")
,/
schließt sich ihnen an:"bcda"
(,/|0 1_)\
Gibt alle Umdrehungen eines Strings zurück(,/|0 1_)\'x
sind die Rotationen jeder Saite inx
1_'
Lässt die erste "Rotation" von jeder fallen, dh jede triviale Identitätsrotation,/
beitretenx^y
ist die Listex
ohne Elemente der Listey
x^x^y
ist der Schnittpunkt vonx
undy
quelle
05AB1E , 14 Bytes
Probieren Sie es online aus!
Erläuterung
quelle
PynTree , 44 Bytes
Probieren Sie es online aus!
Dies stellte sich als schwerwiegender Fehler in der Art und Weise heraus, wie PynTree Listenverständnisse erstellt, da es Funktionen zum Zuweisen von Variablen verwendet, sodass die Zuweisung in Ausdrücken erfolgen kann. Die Bedingungen haben jedoch erst dann den Wert der Variablen, wenn sie ausgewertet wurden und Der Hauptblock wurde ausgewertet. Dies scheint leicht zu beheben zu sein, aber ich habe dies nicht früher bemerkt und daher ist diese Antwort schrecklich lang.
Eigentlich selbst wenn ich das behoben habe, denke ich, dass es immer noch furchtbar lang sein könnte.
quelle
Perl 6 , 65 Bytes
Versuch es
Erweitert:
quelle
JavaScript (Node.js),
10599 ByteUngolfed:
Probieren Sie es online aus!
quelle
Retina 0,8,2 ,
7162 BytesProbieren Sie es online aus! Erläuterung:
Wiederholen Sie dies für jedes Wort.
Stellen Sie die nächste Drehung des Wortes mit einem nachgestellten Zeichen voran
!
.Aber wenn das das ursprüngliche Wort ist, löschen Sie es erneut.
Sortieren Sie die Wörter.
Finde die Duplikate.
quelle
Python 2 ,
665570 BytesProbieren Sie es online aus!
11 Bytes danke an Dennis , um den verketteten
x in y in z
Ansatz zu verwenden.Nimmt eine Reihe von Wörtern
d
; gibt eine Reihe von Rotonymen zurück.quelle
C # (.NET Core) ,
10094 ByteProbieren Sie es online aus!
quelle
Japt , 17 Bytes
Extrem langsam, funktioniert aber. TIO läuft ab, aber ich habe bestätigt, dass es funktioniert, indem die Anzahl der Iterationen in der Sprachquelle manuell verringert wurde.
Probieren Sie es online aus!
quelle
Javascript, 129 Zeichen
Ungolfed
Probieren Sie es online aus!
quelle
Java (JDK 10) , 144 Byte
Probieren Sie es online aus!
quelle
JavaScript (Node.js) , 66 Byte
Probieren Sie es online aus!
langweilige Antwort
quelle