Нумеронимы или N8s?


10

Numeronym (также известный как «численное сокращение»), когда слово укорачивается с помощью чисел. Обычный метод сокращения состоит в том, чтобы использовать длину заменяемой подстроки для замены всех, кроме первого и последнего символов. Например, используйте i18nвместо internationalizationили L10nвместоlocalization . ( LЗаглавная буква, поскольку строчная выглядит слишком похоже на 1.)

Конечно, несколько слов в одной и той же фразе могут иметь одну и ту же сокращенную форму, поэтому ваша задача - преобразовать группу слов в их нумеронимы, или, если существует несколько разных слов с одинаковым нумеронимом, ваша программа должна дать результат A7s R4t, сокращенно Ambiguous Result(да, я знаю, что этот результат сам по себе является неоднозначным результатом.)

Правила:

  • Используйте программу или функцию и напечатайте или верните результат.
  • Ввод принимается как одна строка.
  • Выходные данные представляют собой одну строку слов, разделенных пробелом.
  • Ваша программа не должна преобразовывать слова длиной 3 и не должна преобразовывать более короткие слова.
  • Если l(строчная буква ell) встречается перед 1(одной), она должна быть прописной.
  • Если Iперед 1(одним) должен быть (заглавный глаз) , он должен быть сделан строчными.
  • На входе будет печататься ASCII и пробелы. Слова разделены пробелами.
  • Самый короткий код выигрывает.

Примеры:

A7s R4t -> A7s R4t (OR: A1s R1t, etc)
Ambiguous Result -> A7s R4t
Billy goats gruff -> B3y g3s g3f
Thanks for the Memories -> T4s f1r the M6s (one possible answer, NOT: Thnks fr th Mmrs)
Programming Puzzles & Code Golf -> P9g P5s & C2e G2f
globalization -> g11n
localizability -> L12y
Internationalization or antidisestablishmentarianism -> i18n or a26m
Internationalization or InternXXXXXalization -> A7s R4t
what is this fiddle and faddle -> A7s R4t
A be see -> A be s1e (OR: A be see)
see sea -> s1e s1a (OR: see sea)
2B or not 2B -> 2B or not 2B (OR: 2B or n1t 2B. 2 letters, don't change, don't count as ambiguous)
this example is this example -> t2s e5e is t2s e5e (same words aren't ambiguous)
l1 -> l1 (2 letters, don't change.)
I1 -> I1 (2 letters, don't change.)

Изменить: Если кто-то не получил ссылку: Спасибо от Mmrs


Может ли вход содержать цифры? Если это так, входные данные l1становятся L1или остаются как l1?
Дверная ручка

Я исхожу из упора на другое, что example exampleбыло бы e5e e5e, но было бы хорошо включить тестовый пример, который охватывает это.
Питер Тейлор

Добавлены тестовые случаи для обоих ваших вопросов ( 2B or not 2Bи после.)
mbomb007

Ответы:


1

J, 92 байта

(' 'joinstring(<&(]`(rplc&('I1';'i1')&(rplc&('l1';'L1'))&({.,([:":#-2:),{:))@.(#>3:))&>&;:))

Длинная цепочка составленных звонков. Первая часть - это просто форк: литерал joinstringи функция (в J 1 (10 + +) 2это (10 + (1 + 2))). Вторая часть - это функция. Два rplcвызова должны заменить I / I, когда они могут быть перепутаны. &это составление и составление оператора со значением карри. (поэтому 3&+дает функцию, которая ожидает добавления второго аргумента). Наконец, последняя часть - это функция, которая принимает первое, length-2 (составленное со строковым форматированием) и последнее. &>&;:бит в конце составляет эту функцию (которая должна быть применено к каждому аргументу) к >() распаковка, потому что ;:(сплит слова) возвращает список (коробочный , так что каждый элемент может иметь различную длину).

пример:

     (' 'joinstring(<&(]`(rplc&('I1';'i1')&(rplc&('l1';'L1'))&({.,([:":#-2:),{:))@.(#>3:))&>&;:)) 'hey you baby Iooooooooneey I1'
hey you b2y i11y I1

4

Cache ObjectScript , 231 байт

r(a,b) s o=$REPLACE(o,a,b) q
z(s) f i=1:1:$L(s," ") s u=$P(s," ",i),l=$L(u),o=$S(l<4:u,1:$E(u)_(l-2)_$E(u,l)) d:l>3 r("I1","i1"),r("l1","L1") d  g:r z+4
    . i '(l<4!(v(o)=u!'$D(v(o)))) s r=1 q
    . s v(o)=u,t=t_o_" "
    q t
    q "A7s R4t"

Это было бы хорошим MUMPS, совместимым со стандартами, если бы не этот неприятный $REPLACEвызов, который не является частью стандарта. Реализация этого в чистом М занимает хорошие 80-ые байты, поэтому я не пошел по этому пути.

Точка входа есть $$z("your string here"), которая возвращается "y2r s4g h2e"и так далее.


3
Не могли бы вы, возможно, ссылку на язык? Я не слышал об этом.
mbomb007

Я имею в виду, что это то, что приходит на ум, когда вы за него гугляте ( docs.intersystems.com/cache20152/csp/docbook/… ) - запатентованный вариант MUMPS.
Сеншин

3

C #, 280 274 байта

Первый раз гольфист здесь! В последнее время мне нравилось их читать, и я подумал, что могу попробовать сам! Наверное, не лучшее решение, ну да ладно!

class B{static void Main(string[] a){string[] n=Console.ReadLine().Split(' ');string o="";int j,i=j=0;for(;j<n.Length;j++){int s=n[j].Length;n[j]=((s<4)?n[j]:""+n[j][0]+(s-2)+n[j][s-1])+" ";o+=n[j];for(;i<j;i++)if(n[j]==n[i]){o="A7s R4t";j=n.Length;}}Console.WriteLine(o);}}

То же самое, что не разгневано:

class B
{
    static void Main(string[] a)
    {            
        string[] n = Console.ReadLine().Split(' ');
        string o = "";
        int j, i = j = 0;
        for(; j < n.Length;j++)
        {
            int s = n[j].Length;

            n[j] = ((s<4) ? n[j] : "" + n[j][0] + (s - 2) + n[j][s - 1]) + " ";
            o += n[j];
            for (; i < j; i++)
            {
                if (n[j] == n[i]) { o = "A7s R4t"; j=n.Length;}
            }                              
        }
        Console.WriteLine(o);
    }
}

Спасибо, парни!


Добро пожаловать в PPCG! c:
Deusovi

2

Perl, 131 120 байт

Я добавил байт для использования -pпереключателя:

s/\B(\w+)(\w)/length($1)."$2_$1"/ge;$_="A7s R4t\n"if/(\w\d+\w)(\w+)\b.*\1(?!\2)/;s/_\w+//g;s/I1\w/\l$&/g;s/l1\w/\u$&/g;

объяснение

# Replace internal letters with count, but keep them around for the next test.
s/\B(\w+)(\w)/length($1)."$2_$1"/ge;
# Detect ambiguous result
$_ = "A7s R4t\n" if
    # Use negative look-ahead assertion to find conflicts
    /(\w\d+\w)(\w+)\b.*\1(?!\2)/;
# We're done with the internal letters now
s/_\w+//g;
# Transform case of initial 'I' and 'l', but only before '1'
s/I1\w/\l$&/g;
s/l1\w/\u$&/g;

Не уверен, правильно ли это, но я ожидал, что буква «l» в «like» не станет заглавной при преобразовании в «l2e», поскольку за ней не следует «1».
manatwork

Протестировано всего пару случаев, но похоже на работу: s/(\w)(\w+)(\w)/$1.length($2)."$3_$2"/ges/\B(\w+)(\w)/length($1)."$2_$1"/ge.
manatwork

Спасибо, @manatwork. Я пропустил требование смены регистра [Il]только до того, как 1сэкономил пару байтов!
Тоби Спейт

1

JavaScript (ES6), 165 байт

s=>(r=s.replace(/\S+/g,w=>(m=w.length-2)<2?w:(i=d.indexOf(n=((m+s)[0]<2&&{I:"i",l:"L"}[w[0]]||w[0])+m+w[m+1]))>=0&d[i+1]!=w?v=0:d.push(n,w)&&n,v=d=[]),v?r:"A7s R4t")

объяснение

s=>(                         // s = input string
  r=s.replace(               // r = result of s with words replaced by numeronyms
    /\S+/g,                  // match each word
    w=>                      // w = matched word
      (m=w.length-2)         // m = number of characters in the middle of the word
        <2?w:                // if the word length is less than 4 leave it as it is
      (i=d.indexOf(          // check if this numeronym has been used before
        n=                   // n = numeronymified word
          ((m+s)[0]<2&&      // if the number starts with 1 we may need to replace
            {I:"i",l:"L"}    //     the first character with one of these
              [w[0]]||w[0])+ // return the replaced or original character
          m+w[m+1]
      ))>=0&d[i+1]!=w?       // set result as invalid if the same numeronym has been
        v=0:                 //     used before with a different word
      d.push(n,w)&&n,        // if everything is fine return n and add it to the list
    v=                       // v = true if result is valid
      d=[]                   // d = array of numeronyms used followed by their original word
  ),
  v?r:"A7s R4t"              // return the result
)

Тестовое задание


1

JavaScript ES6, 162

w=>(v=(w=w.split` `).map(x=>(l=x.length-2+'')>1?((l[0]>1||{I:'i',l:'L'})[x[0]]||x[0])+l+x[-~l]:x)).some((a,i)=>v.some((b,j)=>a==b&w[i]!=w[j]))?'A7s R4t':v.join` `

Меньше гольфа

// Less golfed
f=w=>{
  w = w.split` ` // original text splitted in words
  v = w.map(x=> { // build modified words in array v

    l = x.length - 2 // word length - 2
    if (l > 1) // if word length is 4 or more
    {
      a = x[0] // get first char of word
      l = l+'' // convert to string to get the first digit
      m = l[0] > 1 || {I:'i', l:'L'} // only if first digit is 1, prepare to remap I to i and l to L
      a = m[a] || a // remap
      return a + l + x[-~l] // note: -~ convert back to number and add 1
    }
    else
      return x // word unchanged
  })
  return v.some((a,i)=>v.some((b,j)=>a==b&w[i]!=w[j])) // look for equals Numeronyms on different words
  ? 'A7s R4t' 
  : v.join` `
}  

Тестовое задание


1

Python 2, 185 байт

d={}
r=''
for w in input().split():
 l=len(w);x=(w[0]+`l-2`+w[-1]).replace('l1','L1').replace('I1','i1')
 if l<4:x=w
 if d.get(x,w)!=w:r='A7s R4t';break
 d[x]=w;r+=x+' '
print r.strip()

1

Питон 3, 160

Я хотел бы найти хороший способ заменить эти вызовы замены.

def f(a):y=[(x,(x[0]+str(len(x)-2)+x[-1]).replace('l1','L1').replace('I1','i1'))[len(x)>3]for x in a.split()];return('A7s R4t',' '.join(y))[len(set(y))==len(y)]

С некоторыми тестами:

assert f('Billy goats gruff') == 'B3y g3s g3f'
assert f('Programming Puzzles & Code Golf') == 'P9g P5s & C2e G2f'
assert f('Internationalization or InternXXXXXalization') == 'A7s R4t'

1

Фактор, 48 35 байт, неконкурентный

Это лямбда, которая идет в стек, технически не соответствует действительно раздражающе жестким требованиям, которые мне изначально удалось пропустить.

[ " " split [ a10n ] map " " join ]

Использует englishсловарный запас.

Или, если мы вставим a10nслово библиотеки, то 131 байт (с автоимпортом):

: a ( b -- c ) " " split [ dup length 3 > [ [ 1 head ] [ length 2 - number>string ] [ 1 tail* ] tri 3append ] when ] map " " join ;

Это обрабатывает вещи I / L и A7s R4t?
Роберт Фрейзер,

@RobertFraser Я уверен, что так и есть, хотя сейчас я не в компиляторе Factor; Я добавлю прохождение модульных тестов, когда я буду. : D
кошка

Да, извините за требования. Через неделю после того, как я закончил вопрос, я сказал: «О, нет, что я сделал», но было уже слишком поздно. Я мог бы сделать более простую версию в качестве отдельной задачи.
mbomb007
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.