Составить список ротонимов 2

11

Ротонимы 2

«Ротоним» - это слово, которое ROT13 превращается в другое слово (на том же языке).

Для этой задачи мы будем использовать альтернативное определение: «Ротоним» - это слово, которое циклически сдвигается / поворачивается в другое слово (на том же языке).

Например:

'stable' < 'tables' < 'ablest'
'abort' > 'tabor'
'tada' >> 'data'

Соревнование

Напишите программу или функцию, которая принимает список словарей / слов и печатает или возвращает полный список ротонимов.

  1. Заказ не имеет значения.
  2. Сравнения должны быть без учета регистра, так что вы можете предполагать, что ввод будет передан как словарь только для нижнего регистра.
  3. Результат должен быть выражен в виде отдельных слов (не пар) и не содержать дубликатов, поэтому можно предположить, что на входе нет дубликатов.
  4. Это .

пример

Дано

ablest
abort
green
irk
stable
tables
tabor
tata
terra
vex
you

Возвращение

ablest
abort
stable
tables
tabor

Настоящий тест

Дано

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

Возвращение

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
Зонтик
источник
мы можем предположить, что входные слова уникальны?
НГН
Да, я думаю, что предварительно запустил свой ввод через уникальный фильтр, когда запустил системный словарь.
Зонт
Я заметил, что некоторые ответы сработали для примера, но не для полного словаря. Я добавил больший набор тестов, который является подмножеством словаря, достаточно большим, чтобы содержать слова, которые не подходят для некоторых ответов, которые проходят тривиальный пример.
Зонт
@ Зонтик, вы должны комментировать любые недействительные ответы, чтобы предупредить пользователя, чтобы он мог исправить / удалить свой ответ
H.PWiz
abdominovaginalУ тебя там какие-то странные слова.
Волшебная Урна Осьминога

Ответы:

5

Желе , 8 байт

ṙ1$ƬfḊɗƇ

Попробуйте онлайн!

Альтернативная версия, 7 байт

ṙƬ1fḊʋƇ

Dyadic Ƭделал что-то странное, так что это не сработало, когда задача была опубликована.

Попробуйте онлайн!

Как это работает

ṙƬ1fḊʋƇ  Main link. Argument: A (array of strings)

     ʋ   Vier; combine the 4 preceding links into a dyadic chain.
      Ƈ  Comb; for each string s in A, call the chain with left argument s and
         right argument A. Keep s iff the chain returned a truthy value.
 Ƭ           'Til; keep calling the link to the left, until the results are no
             longer unique. Return the array of unique results.
ṙ 1          Rotate the previous result (initially s) one unit to the left.
   f         Filter; keep only rotations that belong to A.
             s is a rotonym iff there are at least two rotations of s in A.
    Ḋ        Deque; remove the first string (s) of the result.
             The resulting array is non-empty / truthy iff s is a rotonym.
Деннис
источник
О новых быстрых персонажей? Хм, нужно узнать, когда использовать их сейчас ... (те же вещи, но 1-байтовый сейчас, так что я могу использовать их больше, чем когда они были 2-байтовыми)
HyperNeutrino
Это эквивалентно ṙ1$ÐĿfḊɗÐf.
Денис
4

APL (Dyalog) , 20 байтов

требует ⎕io←0

⊂∩¨(,/(1↓∘∪⍳∘≢⌽¨⊂)¨)

Попробуйте онлайн!

(1↓∘∪⍳∘≢⌽¨⊂)¨ получает уникальные повороты (исключая саму строку) каждой строки в словаре

принимает длину вектора

⍳∘≢ создает диапазон от 0 до длины

вращает вектор несколько раз, например, 2⌽abort -> ortab

⍳∘≢⌽¨⊂ затем даст все повороты вектора

удаляет дубликаты

1↓ удаляет первый элемент (исходную строку)

,/ сводит все вращения в один список

⊂∩¨ занимает пересечение словаря с вращениями

H.PWiz
источник
ваш результат выходит закрытым, но я думаю, что все должно быть в порядке, и @ Adám может украсть ваш ⊂∩¨трюк (или наоборот) еще на -1
ngn
4

APL (Dyalog Unicode) , 25 23 22 17 16 байт SBCS

Заимствует идеи из решения ngn / ngn / k . А потом -6 благодаря ему. Также -1, возвращая вложенный список как H.PWiz .

Функция анонимного молчаливого префикса.

⊂∩¨1,.↓(∪≢,/,⍨)¨

Попробуйте онлайн!

( Применить следующую молчаливую функцию к каждому слову:

,⍨ объединить слово с собой

≢,/ все подстроки длины слова (то есть все вращения)

 уникальные элементы этих вращений (чтобы слова не tataпоявлялись дважды)

1,.↓ объединение дроп-первых (исходных слов) каждого списка

⊂∩¨ пересечение содержания этого и всего оригинального списка слов


Старое решение

-2 благодаря нгн.

Анонимный префикс лямбда.

{⍵/⍨2≤+/⍵∊⍨↑(∪≢,/,⍨)¨⍵}

Попробуйте онлайн!

{} Функция где список слов:

( Применить следующую молчаливую функцию к каждому слову:

  ,⍨ объединить слово с собой

  ≢,/ все подстроки длины слова (то есть все вращения)

   уникальные элементы этих вращений (чтобы слова не tataпоявлялись дважды)

 смешать список списков в одну матрицу (площадки со строками из пробелов)

⍵∊⍨ указать, какие элементы матрицы являются членами исходного списка

+/ суммировать строки (подсчитывает вхождения каждого из исходных слов)

2≤ указать, у кого есть дубликаты (то есть, если они не возвращены к оригиналу)

⍵/⍨ используйте это для фильтрации исходного списка

Адам
источник
{∪⌽∘⍵¨⍳≢⍵}-> (∪≢,/,⍨); ваше использование умно
нгн
@ngn Спасибо. Я научился этому трюку от Мортена.
Адам
эти поезда делают мой мозг болит ... это проще, как dfn:{⍵∩⊃,/1↓¨(∪≢,/,⍨)¨⍵}
ngn
@ngn Это то, что я сделал, хотя и превратил в поезд и без уловки вращений
H.PWiz
1
извините, последнее изменение в ⊢∩∘⊃1,.↓(∪≢,/,⍨)¨
своем мнении
4

Брахилог , 26 байт

g;?z{tWl⟧₆∋I;W↺₍R;W≠&h∋R}ˢ

Попробуйте онлайн!

g;?z                          % Zip the whole input with each word in it respectively
    {                   }ˢ    % Apply this predicate to each pair in the zip
                              %   and select the successful values
     tW                       % Let the current word be W
       l⟧₆∋I                  % There exists a number I from 1 to length(W)-1
            ;W↺₍R             % And R is the result of circularly shifting the 
                              %   current word I times 
                 ;W≠          % And R is not the current word itself (needed for words like "tata")
                    &h∋R      % And R is one of the input dictionary words
                              % (R is implicitly the output of the predicate, and 
                              %  successful R values are collected and output by the ˢ)
sundar - Восстановить Монику
источник
3

Python 2 , 73 69 67 байт

lambda d:[w for w in d if{w[i:]+w[:i]for i in range(len(w))}-{w}&d]

Попробуйте онлайн!

Принимает набор слов (строчные буквы) и возвращает список ротонимов.


Сохраненный

  • -2 байта, благодаря овсу
TFeld
источник
3

К (нгн / к) , 23 байта

{x^x^,/1_'(,/|0 1_)\'x}

Попробуйте онлайн!

{ } это функция с аргументом x

0 1_вырезает строку с индексами 0 и 1, например "abcd"->(,"a";"bcd")

| переворачивает два ломтика: ("bcd";,"a")

,/ присоединяется к ним: "bcda"

(,/|0 1_)\ возвращает все повороты строки

(,/|0 1_)\'x повороты каждой строки в x

1_' отбрасывает первое «вращение» каждого, то есть каждое тривиальное вращение идентичности

,/ присоединиться

x^yсписок xбез элементов спискаy

x^x^yэто пересечение xиy

СПП
источник
Умная. Я смог использовать часть пересечения, чтобы сохранить еще один байт.
Адам
2

05AB1E , 14 байтов

εDvDÀ})ÙåO<Ā}Ï

Попробуйте онлайн!

объяснение

ε           }    # apply to each word in the input
 Dv  }           # for each letter in the word
   DÀ            # copy the previous word and rotate it left
      )Ù         # wrap the rotations in a list and remove duplicates
        å        # check each rotation for presence in the input
         O       # sum presences
          <Ā     # decrement the sum and truthify it (check if 1 or greater)
             Ï   # filter, keep words in input that are true in the resulting list
Emigna
источник
2

PynTree , 44 байта

§y:f#x0€[x/|Ḟz&⁻xzėzḞw+#x`wLx#x`0wRLxy]y#\x1

Попробуйте онлайн!

Оказалось, что это выявило серьезный недостаток в способах, которыми PynTree создает списочные выражения, поскольку он использует функции для присваивания переменных, так что присваивание может идти в выражениях, но затем условия не имеют значения переменной до тех пор, пока она не будет оценена и основной блок был оценен. Кажется, это легко исправить, но я не заметил этого раньше, и поэтому этот ответ ужасно длинный.

На самом деле, даже если я исправлю это, я думаю, что это все еще может быть ужасно долго.

HyperNeutrino
источник
2

Perl 6 , 65 байт

{@^a.grep:{@aany(($/=[.comb]).rotate,*.rotate...^*eq$/).join}}

Попробуй

Expanded:

{  # bare block lambda with placeholder parameter @a

  @^a     # declare and use placeholder parameter
  .grep:  # find the values that match
  {

    @a
                # Set contains operator

    any(         # create a junction of the following

      # generate a sequence
      (
        $/ =     # store into $/ (no declaration needed for this variable)
        [        # turn into an array instead of a one-time sequence
          .comb  # the input split into characters
        ]
      ).rotate,  # start the sequence on the first rotation

      *.rotate   # use this to generate the rest of the values in the sequence

      ...^       # keep generating values until: (and throw out last value)

      * eq $/    # one of them matches the cached array of the input

    ).join       # for each array in the junction join the strings (no spaces)
  }
}
Брэд Гилберт b2gills
источник
2

JavaScript (Node.js), 105 99 байт

f=l=>l.filter(w=>[...Array(k=w.length)].map((x,i)=>(w+w).substr(i,k)).some(r=>l.includes(r)&&r!=w))

Ungolfed:

f = list =>
  list.filter( word =>
    // create a list of all rotonyms for the current word
    [ ...Array( len = word.length ) ]
      .map( (x,i) => 
         ( word+word ).substr(i, len)
      )
    // check if any of the rotonyms is in the initial dictionary/wordlist
     .some( rotonym =>
        list.includes( rotonym )
    // and is not the word itself
        && rotonym != word
     )

Попробуйте онлайн!

bubens
источник
Добро пожаловать в PPCG! Я не разбираюсь в JavaScript, но обязательно ознакомьтесь с веткой JavaScript Tips, чтобы увидеть, есть ли здесь что-нибудь подходящее.
AdmBorkBork
Спасибо за подсказку. Я прочитал ответы как для JS, так и для ES6, но, похоже, я уже применил все соответствующие советы для этого. По крайней мере, те, которые были очевидны для меня.
Бубенс
1

Retina 0.8.2 , 71 62 байта

^(\w)(\w*)
$2$1!¶$&
%+)s`^(.+)(!.*¶\1)$
$2
O`
!`\b(.+)(?=¶\1!)

Попробуйте онлайн! Объяснение:

%+)

Повторите для каждого слова.

^(\w)(\w*)
$2$1!¶$&

В начале следующего поворота слова ставится завершающий символ !.

s`^(.+)(!.*¶\1)$
$2

Но если это оригинальное слово, то удалите его снова.

O`

Сортировать слова

!`\b(.+)(?=¶\1!)

Найдите дубликаты.

Нил
источник
1

Python 2 , 66 55 70 байт

lambda d:{w for w in d for v in d if v not in w not in v in w*2in v*3}

Попробуйте онлайн!

11 байтов спасибо Деннису, чтобы использовать цепной x in y in zподход.

Принимает набор слов d; возвращает набор Ротонимов.

Час Браун
источник
Чек слишком слабый; {ab, abab} передаст это.
xnor
@xnor: черт побери! Быстрое решение ...
Час Браун
0

Japt , 17 байт

Очень медленно, но работает. Время ожидания TIO истекло, но я подтвердил, что он работает, уменьшив количество итераций в источнике языка вручную.

f@_XéZ ÀX©UøXéZ}a
f@                // Filter the input array by
  _            }a // generating up to 1e8 rotations of each string
   XéZ ÀX         // and checking if the rotation is different than the original,
         ©UøXéZ   // yet still exists in the input array.

Попробуйте онлайн!

гнида
источник
Почему так много итераций? Сначала я выполнял итерации для длины строки, но в ходе тестирования выяснилось, что десяти поворотов влево на слово было достаточно, чтобы найти все случаи в файле dict MacOS.
Зонт
@ Зонт, потому что это коротко писать. Вопрос в коде гольфа, а не в быстром коде.
Нит
Понимаю. Я незнаком с Джаптом, поэтому для меня не было очевидным, что итерация меньше потребует больше символов.
Зонт
0

Javascript, 129 символов

f=a=>{n={};r=w=>w.slice(1,w.length)+w[0];a.map(w=>{m=r(w);while(m!=w){if(-~a.indexOf(m))n[m]=1;m=r(m);}});return Object.keys(n);}

Ungolfed

f=a=>{
    n={};
    r=w=>w.slice(1,w.length)+w[0];
    a.map(w=>{
        m=r(w);
        while(m!=w){
            if(-~a.indexOf(m))n[m]=1;
            m=r(m);
        }
    });
    return Object.keys(n);
}

Попробуйте онлайн!

Asleepace
источник
0

JavaScript (Node.js) , 66 байт

s=>s.filter(t=>s.some(u=>(t+t).match(u)&&t!=u&t.length==u.length))

Попробуйте онлайн!

скучный ответ

l4m2
источник
Это не работает правильно. Проверьте это по сравнению с большим набором тестов, который я добавил
Зонт