Numerônimos ou N8s?

10

Um numerônimo (também conhecido como "contração numérica") ocorre quando uma palavra é reduzida usando números. Um método comum de contração é usar o comprimento da substring substituída para substituir todos, exceto o primeiro e o último caracteres. Por exemplo, use em i18nvez de internationalizationou em L10nvez delocalization . (O valor Lé maiúsculo, uma vez que uma minúscula se parece muito com a 1.)

Obviamente, várias palavras na mesma frase podem ter a mesma forma abreviada; portanto, seu trabalho é converter um grupo de palavras em seus numerônimos ou, caso exista algumas palavras diferentes com o mesmo numerônimo, seu programa deve fornecer um resultado de A7s R4t, abreviação de Ambiguous Result(sim, eu sei que esse resultado é um resultado ambíguo.)

Regras:

  • Use um programa ou função e imprima ou retorne o resultado.
  • A entrada é tomada como uma única sequência.
  • A saída é uma única sequência de palavras delimitadas por espaço.
  • Seu programa não precisa converter palavras com o comprimento 3 e não deve converter palavras mais curtas.
  • Se um l(ell em minúsculas) ocorrer antes de um 1(um), ele deve ser colocado em maiúsculas.
  • Se um I(olho em maiúscula) ocorrer antes de um 1(um), ele deverá estar em minúscula.
  • A entrada será ASCII e espaços imprimíveis. As palavras são separadas por espaços.
  • O menor código vence.

Exemplos:

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.)

Edit: Se alguém não obteve a referência: Thnks fr th Mmrs

mbomb007
fonte
A entrada também pode conter números? Nesse caso, uma entrada de l1tornar L1- se ou permanecer como l1?
Maçaneta
Presumo que, com ênfase no que seria diferente , seria bom incluir um caso de teste que cubra isso. example examplee5e e5e
Peter Taylor
Casos de teste adicionados para as duas perguntas ( 2B or not 2Be depois.) #
Mbomb007

Respostas:

1

J, 92 bytes

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

Uma longa cadeia de chamadas compostas. A primeira parte é apenas uma bifurcação: uma literal joinstring, e uma função (em J, 1 (10 + +) 2é (10 + (1 + 2))). A segunda parte é a função. As duas rplcchamadas são para substituir o I / l quando puderem ser confundidas. &é composição e compondo um operador com um valor atual. ( 3&+fornece uma função que espera que o segundo argumento seja adicionado). Finalmente, a última parte é a função que leva a primeira, o comprimento-2 (composto com stringificação) e a última. o &>&;:bit no final compõe esta função (que deve ser aplicada a todos os argumentos) para >(sem caixa), porque ;:(palavras divididas) retorna uma lista em caixa (para que cada elemento possa ter comprimento diferente).

exemplo:

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

ObjectScript em cache , 231 bytes

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"

Seria um bom MUMPS compatível com os padrões, se não fosse por essa $REPLACEchamada traquina , que não faz parte do padrão. Reimplementá-lo em M puro requer bons 80 bytes, por isso não segui esse caminho.

O ponto de entrada é $$z("your string here"), que retorna "y2r s4g h2e"e assim por diante.

senshin
fonte
3
Você poderia talvez criar um link para o idioma? Eu não ouvi falar disso.
Mbomb007
Quero dizer, é o que surge quando você pesquisa no Google ( docs.intersystems.com/cache20152/csp/docbook/… ) - um sabor exclusivo do MUMPS.
senshin
3

C #, 280 274 bytes

Primeira vez golfista aqui! Tenho gostado de ler isso ultimamente e então pensei em experimentar alguns! Provavelmente não é a melhor solução, mas tudo bem!

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);}}

A mesma coisa não destruída:

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);
    }
}

Obrigado rapazes!

SkyPharaoh
fonte
Bem-vindo ao PPCG! c:
Deusovi 28/03
2

Perl, 131 120 bytes

Adicionei um byte para usar a -popção:

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;

Explicação

# 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;
Toby Speight
fonte
Não tenho certeza se está correto, mas esperava que o "l" em "like" não fosse capitalizado quando transformado em "l2e", como não é seguido por "1".
Manatwork
Testou apenas alguns casos, mas parece funcionar: s/(\w)(\w+)(\w)/$1.length($2)."$3_$2"/ges/\B(\w+)(\w)/length($1)."$2_$1"/ge.
Manatwork
Obrigado, @manatwork. Eu negligenciei o requisito de caseswap [Il]apenas antes 1- salvei alguns bytes também!
perfil completo de Toby Speight
1

JavaScript (ES6), 165 bytes

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")

Explicação

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
)

Teste

user81655
fonte
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` `

Menos golfe

// 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` `
}  

Teste

edc65
fonte
1

Python 2, 185 bytes

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()
TFeld
fonte
1

Python 3, 160

Gostaria de encontrar uma boa maneira de substituir as chamadas de substituição.

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)]

Com alguns casos de teste:

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'
Morgan Thrapp
fonte
1

Fator, 48 35 bytes, não-competitivo

É um lambda que fica na pilha, que tecnicamente não atende aos requisitos realmente irritantemente difíceis que eu originalmente consegui ignorar.

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

Usa o englishvocabulário.

Ou, se incorporarmos a a10npalavra da biblioteca, em seguida, 131 bytes (com importação automática):

: a ( b -- c ) " " split [ dup length 3 > [ [ 1 head ] [ length 2 - number>string ] [ 1 tail* ] tri 3append ] when ] map " " join ;
gato
fonte
Isso lida com o material de i / L e o A7s R4t?
Robert Fraser
@RobertFraser Tenho certeza de que sim, apesar de não estar em um compilador do Factor neste minuto; Vou adicionar testes de unidade aprovados quando estiver. : D
cat
Sim, desculpe pelos requisitos. Uma semana depois de terminar a pergunta, fiquei tipo "oh não, o que eu fiz", mas já era tarde demais. Eu poderia fazer uma versão mais simples como um desafio separado.
mbomb007