Напишите регулярное выражение, которое работает как минимум в двух вариантах (или версиях) регулярных выражений, и сопоставьте разные строки в каждом варианте (или версии), в котором он работает.
Строки, которые должны быть сопоставлены в этой задаче, являются первыми словами кодовых имен Ubuntu, которые перечислены ниже. Ваше регулярное выражение должно совпадать с верхней части списка. То есть, если ваши регулярные выражения работает в 3 -х вкусах, он должен соответствовать Warty
Hoary
и Breezy
, а не другим.
Warty
Hoary
Breezy
Dapper
Edgy
Feisty
Gutsy
Hardy
Intrepid
Jaunty
Karmic
Lucid
Maverick
Natty
Oneiric
Precise
Quantal
Raring
Saucy
Trusty
Utopic
Vivid
Wily
Xenial
Yakkety
Zesty
17.10
18.04
18.10
19.04
19.10
...
Если ваше регулярное выражение работает в более чем 26 вариантах, вместо этого вы можете сопоставить номера версий Ubuntu. Начиная с 17.10, для каждого нового аромата измените второе число на 10, если оно было 04, и увеличьте первое число и измените второе на 04 в противном случае.
В каждом варианте ваше регулярное выражение должно соответствовать только предполагаемой строке и ничему другому (не ограничиваясь кодовыми именами). Замыкающие переводы не имеют значения. Это означает, что ваше регулярное выражение может либо соответствовать только строке без завершающей строки, либо совпадать только с последней строкой строки, либо совпадать с обеими. И это не должно быть последовательным в разных вкусах. Вы можете предполагать, что входные данные находятся в печатном ASCII (за исключением завершающего перевода строки, если он есть).
Ваша оценка (длина вашего кода + 10) / ((количество ароматов) ^ 2). Самый низкий балл побеждает.
источник
Ответы:
87 байт, 5 ароматов, (87 + 10) / 25 = 3,88
На данный момент я пошел с простыми для тестирования вкусами, а именно:
Общая структура такова
^((...)y|...)$
, то есть выделение конечныхy
символов и добавление якорей.Бородавка (PCRE)
В PCRE и Ruby
[[:word:]]
- это символьный класс POSIX, соответствующий символу слова - в других вариантах вы получаете[[:word:]
символьный класс, а не литерал&&]
, что не соответствует(?=W)
утверждению. Чтобы заставить Ruby потерпеть неудачу,&&
используется для пересечения класса POSIX ни с чем, тогда как в PCRE&&
не имеет особого значения.Седой (Javascript)
По какой-то причине Javascript - это единственный вариант из множества, где
\a
есть литералa
- в других вариантах он соответствует символу колокольчика (ASCII 7).Бризи (Питон)
В Python и Javascript
\z
это литералz
- в других вариантах он эквивалентен$
концу строки привязки. Чтобы сделать Javascript неудачным, мы используем класс char[]e]
, который является пустым классом char,[]
затем литеральнымe]
в Javascript, и класс с двумя символами[]e]
в Python.Dapper (.NET)
In
.NET
,[D-[E]]
- это разность множеств, удаляющих множество[E]
из[D]
. В PCRE, Javascript и Python у нас есть класс, а[D-[E]
затем литерал]
. Ruby немного отличается, но по какой-то причине он анализируется как класс,[D-[E]]
который только соответствуетE
, и мне еще предстоит выяснить, почему ...Острый (Рубин)
Ruby допускает классы char внутри классов char, поэтому
[[d]]
фактически эквивалентен[d]
или простоd
. В других вариантах мы имеем[[d]
буквальное значение]
.источник