Tabela periódica dos elementos - Code Golf

47

Baseado no golfe prático - Estados dos EUA

Sua tarefa é encontrar a abreviação (símbolo) de um elemento com o nome do elemento, até ununoctium (118). Use a tabela periódica na Wikipedia .

Graças à ossifração sensível, você pode encontrar uma lista completa de elementos para abreviações em http://pastebin.com/DNZMWmuf .

Você não pode usar nenhum recurso externo. Além disso, você não pode usar nenhum dado interno especificamente sobre os elementos da tabela periódica. Aplicam-se brechas padrão.

Entrada

Entrada pode ser de stdin, arquivo prompt, inputetc.

Formato de entrada:

Todos os seguintes são entradas válidas:

Carbon
carbon
CARBON
cArBOn

Essencialmente, o nome do elemento - não diferencia maiúsculas de minúsculas.

Você não precisa lidar com erros de ortografia ou qualquer nome de elemento inválido. Entrada inválida é um comportamento indefinido.

Saída :

O símbolo para o elemento O primeiro caractere deve ser capitalizado eo resto deve estar em letras minúsculas.

Exemplo de saída: C

Casos de teste:

Carbon -> C
NiTROGen -> N
Sodium -> Na
Gold -> Au
Silver -> Ag
Tin -> Sn

Existem muitos outros elementos além dos estados, portanto, espero que seja mais difícil encontrar uma regra geral para eles.

Isso é código de golfe. O código mais curto vence!

soktinpk
fonte
4
@squeamishossifrage Thanks. Ambas as versões ("enxofre" e "enxofre") são aceitáveis. Seu programa não precisa lidar com ambos, no entanto, apenas um.
S03_14
1
... impossível de fazer com expressões regulares. Você nos deixou bem.
Josiah Winslow
2
@Xrylite Tente ler as regras: " Entrada ... o nome do elemento - não diferencia maiúsculas de minúsculas ... Saída ... O primeiro caractere deve estar em maiúsculas e o restante em minúsculas".
Jim Balter
2
E quanto à ortografia adequada (alumínio) versus ortografia americana (alumínio)?
Paul R
4
@codebreaker Sim, se a entrada não for válida, seu programa poderá travar, travar, imprimir Auou o que você quiser. @Paul R Se houver muitas maneiras de soletrar um elemento (por exemplo, enxofre x enxofre ou alumínio x alumínio), use o que reduzir o tempo do programa. Você não precisa lidar com os dois casos.
soktinpk

Respostas:

27

CJam, 337 297 293 232 220 201 200 bytes

leu:E2f^3b2+4%_"53N5903CVCT4":i3/=~Ef+b\%]53b"gØâ^ÃP·^À4ξ^ß^E5^W^Ma{áª^B¤±´oòæ»^XÊQÑ»4žDÙÝòÙ 0^ÝþKa6^Ó£,Ûkû¥¡ùh^E"256b7b6a/0a3**<)5md@5a/,(" ¬^GH/N¿·%^U^RU1²Bd
òë^м~í^ÌéáU"256b25b'Af+2/='J-'Q/"UU"*\)_5=)*E%2<?(\el

O código acima usa notação de sinal de intercalação, pois contém caracteres de controle.

Ao custo de 24 bytes adicionais (para um total de 224), esses caracteres podem ser evitados.

leu:E2f^3b2+4%_"53N5903CVCT4":i3/=~Ef+b\%]53b
"' NwEvKv6e8@]jO4G)=b{L!v@hFQ/oCN)*|BRxvNRL+LO7NI(pLs4[d87$Q%8R\t+' M5JU"
{32f-95b}:B~7b6a/0a3**<)5md@5a/,(
"&y.$h*z^t\rQPUc]l8F h$=18C^r|vD~S"
B25b'Af+2/='J-'Q/"UU"*\)_5=)*E%2<?(\el

Você pode tentar esse código no intérprete CJam .

Casos de teste

$ base64 -d > elements.cjam <<< bGV1OkUyZl4zYjIrNCVfIjUzTjU5MDNDVkNUNCI6aTMvPX5FZitiXCVdNTNiImfY4oNQt4A0zr6fBTUXDWF74aoCpLG0b/LmuxjKUdG7NMW+RNnd8tmgMJ3+S2E2k6Ms22v7paH5aAUiMjU2YjdiNmEvMGEzKio8KTVtZEA1YS8sKCIgrAdIL06/tyUVElUxskJkCvLrkLx+7Yzp4VUiMjU2YjI1YidBZisyLz0nSi0nUS8iVVUiKlwpXzU9KSpFJTI8PyhcZWw=
$ cksum elements.cjam 
952664534 200 elements.cjam
$ for e in Carbon NiTROGen Sodium Gold Silver Tin; do LANG=en_US cjam elements.cjam <<< $e; echo; done
C                                                                                                       
N                                                                                                       
Na                                                                                                      
Au                                                                                                      
Ag                                                                                                      
Sn

Como funciona

O primeiro passo é ler o nome do elemento em STDIN e aplicar uma função hash bastante elaborada, que mapeia todos os nomes de elementos no intervalo [0, 225] :

l eu :E          " Read a line from STDIN, convert to uppercase and save in E.            ";
2 f^             " XOR each character code with 2.                                        ";
3 b              " Convert to integer; consider the resulting array a base 3 number.      ";
2 + 4 %          " Add 2 and take the result modulo 4. Result: R                          ";
"53N5903CVCT4":i " Push [53 51 78 53 57 48 51 67 86 67 84 52].                            ";
3 / =            " Retrieve the chunk of length 3 that corresponds to R. Result: C        ";
~ E f+           " Add C[2] to all character codes of E.                                  ";
b                " Convert to integer; consider the resulting array a base C[1] number.   ";
\ %              " Take the integer modulo C[0]. Result: M                                ";
] 53 b           " Push H := 53 * R + M.                                                  ";

Muitos símbolos de elementos são formados pelo primeiro e segundo, primeiro e terceiro, primeiro e quarto, primeiro e quinto ou primeiro e décimo (que é apenas o primeiro) caractere do nome em inglês do elemento. Vamos representar esses elementos por números de 0 a 4, respectivamente. Todos os elementos restantes (representados por 5) exigirão uma tabela de pesquisa.

A tabela resultante pode ser pressionada da seguinte maneira:

"gØâ^ÃP·^À4ξ^ß^E5^W^Ma{áª^B¤±´oòæ»^XÊQÑ»4žDÙÝòÙ 0^ÝþKa6^Ó£,Ûkû¥¡ùh^E"256b7b6a/0a3**

A matriz de códigos de caracteres é convertida da base 256 para a base 7 e 6 e é substituída por execuções de três zeros.

Esta é a tabela de decisão D:

[4 0 0 0 1 0 0 0 0 0 0 3 0 2 0 1 0 0 0 0 0 0 0 0 4 1 1 0 0 0 0 2 0 4 0 5 2 0 0 3 4 0 0 0 0 4 0 1 0 0 3 1 0 0 2 1 1 1 0 0 0 1 0 5 5 0 0 2 0 0 0 5 5 0 0 0 5 0 3 0 0 0 0 5 0 0 0 0 0 0 0 0 5 2 3 0 1 0 5 0 4 0 0 0 0 4 0 5 0 0 0 0 0 5 0 0 0 2 5 1 4 1 5 0 0 0 5 0 0 5 1 1 0 0 0 0 0 0 2 0 5 0 0 0 3 1 0 2 0 0 0 2 0 0 0 5 0 0 0 0 1 0 0 0 0 0 4 0 2 2 5 2 0 0 5 1 0 0 0 0 4 0 5 0 0 3 5 0 0 5 0 1 0 0 0 2 0 0 0 0 0 5 0 4 0 0 0 0 0 0 0 0 3 0 4 0 0 1 2 2 0 0 0 0 0]

A ação necessária para o elemento com o hash 1 , por exemplo, corresponde ao primeiro elemento dessa matriz. Os elementos da matriz que não correspondem ao hash de nenhum elemento também são zero, o que permite a compressão (0 0 0) ↦ 6 .

Agora, interpretamos D para o hash H.

< ) 5 md     " Push D[:H-1] (D[H-1] / 5) (D[H-1] % 5).                                    ";
@ 5a / , (   " Count the number of 5's in D[:H-1] (by splitting at [5]). Result: I        ";

Em seguida, pressionamos a tabela de pesquisa. Se anexarmos j aos símbolos de um caractere e substituir Uu por Q , cada símbolo terá exatamente dois caracteres. Pode ser pressionado da seguinte maneira:

" ¬^GH/N¿·%^U^RU1²Bd
òë^м~í^ÌéáU"256b25b'Af+2/

A matriz de códigos de caracteres é convertida da base 256 para a base 25, o código de caracteres A é adicionado a todos os dígitos (conversão para Caractere no processo) e o resultado é dividido em partes de comprimento dois.

Esta é a tabela de pesquisa L:

["QP" "YB" "PD" "SN" "QO" "QT" "QS" "SB" "KJ" "TM" "FE" "PB" "AU" "WJ" "CN" "SG" "RF" "CM" "CU" "HG" "NA" "RG" "AG"]

Agora, passamos a calcular nomes de elementos em potencial.

=                " Push L[I].                                                             ";
'J - 'Q / "UU" * " Remove J's and replace Q's with runs of two U's.                       ";
\ ) _ 5 = ) *    " Push S := (D[H-1] % 5 + 1) * ((D[H-1] % 5 + 1 == 5) + 1).              ";
E %              " Push every Sth character of E.                                         ";
2 <              " Discard all but the first two characters.                              ";

A pilha agora contém

B M N

onde B é o booleano D [H-1] / 5 , M é o nome recuperado da tabela de pesquisa e N é o nome do elemento formado pela seleção de caracteres de E.

Estamos quase terminando:

?                " If B, push M; else, push N.                                            ";
( \              " Extract the first character from the string.                           ";
el               " Convert the rest to lowercase.                                         ";
Dennis
fonte
Mas como isso funciona?
Claudiu
2
@ Claudiu: Eu adicionei uma explicação.
Dennis
3
Eu li o primeiro terço da explicação, e até agora o que tenho é "Magia". Incrível
Mooing Duck
7
"AcAlAmSbArAsAtBaBkBeBiBhBBrCdCsCaCfCCeClCrCoCnCuCmDsDbDyEsErEuFmFlFFrGdGaGeAuHf HsHeHoHInIIrFeKrLaLrPbLiLvLuMgMnMtMdHgMoNdNeNpNiNbNNoOsOPdPPtPuPoKPrPmPaRaRnReRh RgRbRuRfSmScSgSeSiAgNaSrSTaTcTeTbTlThTmSnTiWUuoUupUusUutUVXeYbYZnZr" = 226 caracteres. Sua solução = 200 caracteres. Há algum vodu apropriado acontecendo aqui.
Ossifrage squeamish # 9/14
Aceitei esta resposta porque parece ser a mais curta, mas fique à vontade para postar respostas adicionais.
soktinpk
43

C, 452

Uma boa função de hash ajuda. Pode haver melhores. (Melhorias sugeridas por @ugoren et al.)

h;main(c){char*p="Sn)Cu&V$U#Mo#Rf#Sg&Cs#Y+FTa%Rb)S'Nd#GaK&Mg'Zr$PtPm%ReUuo#SmDy(Ac$Lu%W&CaRa(Cf)EuB#Ds%Md$Uus*NpIn$H&YbIr*BeEs*Tc#I(FlRuC#ThSrBh/NaCoLrKr&Nb$CePb$Ne'Am)At*PdLa#Tl%HgMt,CrTbBk$Rh&Rn4TeZn$HfAg%Fm)Xe$AlScFePo$As'HeO#LvN&DbGe#Ho&Mn$Cd+Ni$Rg$HsBr$AuSi#Pr&Uup#Se*Ti#Tm$Er$Sb&PPu&Cm$GdBa'Cn&UutLiFr#Ar#Bi#NoOs%Pa4Cl";while((c=getchar())>64)h=(h+c%32+74)*311%441;while(h)if(*p<65?h-=*p++-34,0:1)for(h--;*++p>96;);do putchar(*p++);while(*p>96);}

Ungolfed com comentários:

int h;
main(c) {

  /* Hashed element symbols. Characters #$% etc. are used as padding: */
  char *p="Sn)Cu&V$U#Mo#Rf#Sg&Cs#Y+FTa%Rb)S'Nd#GaK&Mg'Zr$PtPm%ReUuo#SmDy(Ac$Lu%W&C"
          "aRa(Cf)EuB#Ds%Md$Uus*NpIn$H&YbIr*BeEs*Tc#I(FlRuC#ThSrBh/NaCoLrKr&Nb$CeP"
          "b$Ne'Am)At*PdLa#Tl%HgMt,CrTbBk$Rh&Rn4TeZn$HfAg%Fm)Xe$AlScFePo$As'HeO#Lv"
          "N&DbGe#Ho&Mn$Cd+Ni$Rg$HsBr$AuSi#Pr&Uup#Se*Ti#Tm$Er$Sb&PPu&Cm$GdBa'Cn&Uu"
          "tLiFr#Ar#Bi#NoOs%Pa4Cl";

  /* This hash function gives a unique result for each element: */
  while((c=getchar())>64) h=(h+c%32+74)*311%441;

  /* Find the corresponding position in the hashed data */
  while(h) {
    if(*p<65?h-=*p++-34,0:1) {      /* Step over an abbreviation */
      for(h--;*++p>96;);            /* Skip padding */
    }
  }

  /* Output first uppercase character and all following lowercase characters: */
  do {
    putchar(*p++);
  } while(*p>96);
}

Usei força bruta para encontrar esse hash; Este foi o único com um tamanho de hash ≤512 que não teve colisões. Porém, não verifiquei ortografia alternativa e pode haver funções melhores com algoritmos diferentes (por exemplo, usando XOR em vez de adição).

A função hash mapeia seqüências de caracteres de texto para valores de 0 a 440. "Tin" hashes para zero, portanto "Sn" está no início da tabela. As próximas 7 posições estão vazias. Para manter o código compacto, isso é indicado pelo valor ASCII 34 + 7 = 41 (")"). Em seguida, vem "Cobre" (8), quatro células vazias (34 + 4 = 38 = "&") e "Vanádio" (13). Depois de calcular um hash, o programa percorre a tabela, subtraindo 1 para cada letra maiúscula seguida por 0 ou mais letras minúsculas e subtraindo (ASCII VALUE) -34 para cada caractere que não seja do alfabeto. Quando o valor chega a zero, encontramos o resultado correto.

ossifrage melindroso
fonte
3
@soktinpk Brute forçou :-) Este foi o único com um tamanho de hash ≤512 que não teve colisões. Porém, não verifiquei ortografia alternativa e pode haver funções melhores com algoritmos diferentes (por exemplo, usando XOR em vez de adição).
squishish ossifrage
2
Faça isso 464 ... você tem um par de chaves desnecessário.
Jim Balter
1
Se você pensa sobre a gramática, é inequívoca e deve ser permitida ... apenas parece ambígua para nós . Ah, e você pegou outro que eu não peguei! Parabéns por isso ... Eu tentei muito apertar o algoritmo, mas você conseguiu tudo certo.
Jim Balter
5
@Harshdeep - A função hash mapeia as seqüências de texto para valores de 0 a 440. "Tin" hashes para zero, então "Sn" está no início da tabela. As próximas 7 posições estão vazias. Para manter o código compacto, isso é indicado pelo valor ASCII 34 + 7 = 41 (")"). Em seguida, vem "Cobre" (8), quatro células vazias (34 + 4 = 38 = "&") e "Vanádio" (13). Depois de calcular um hash, o programa percorre a tabela, subtraindo 1 para cada letra maiúscula seguida por 0 ou mais letras minúsculas e subtraindo (ASCII VALUE) -34 para cada caractere que não seja do alfabeto. Quando o valor chega a zero, encontramos o resultado correto.
Ossifrage melindroso
2
Agradável. Salve alguns caracteres com: 1 (h+c%32+74)*311%441.. 2. Solte pe use s. 3. main(c)salva uma vírgula.
Ugoren
13

JavaScript ES6, 690 708 bytes

for(n=prompt()[l='toLowerCase'](i=0);!(c='HHeLiBeBCNFNeNaMgAlSiPSClArKCaScTiVCrMnFeCoNiCuZnGaGeAsSeBrKrRbSrYZrNbMoTcRuRhPdAgCdInSnSbTeIXeCsBaLaCePrNdPmSmEuGdTbDyHoErTmYbLuHfTaWReOsIrPtAuHgTlPbBiPoAtRnFrRaAcThPaUNpPuAmCmBkCfEsFmMdNoLrRfDbSgBhHsMtDsRgCnUutFlUupLvUusUuo'.match(x=/[A-Z][a-z]*/g)['HyHeLitBeryBorCarNitFluNeonSoMagAlSiliPhSuChlArgPotCalcScTitVChrManIroCobNicCoppZinGalGeArsSelBrKRubStYttrZirNioMoTecRuthenRhoPaSilvCadInTinAnTelIoXCaeBaLanCePraNeodPromSaEuGadTerDyHoErThuYtteLuHafTaTuRheOsIriPlaGoMerThaLeBiPolAsRadoFrRadiAcThoProtUrNepPluAmCuBerkCaliEiFeMenNoLawRutherDuSeaBohHasMeiDaRoCopeUnuntFleUnunpLivUnunsUnuno'.match(x).map(a=>a[l]()).indexOf(n.slice(0,i++))]);)
alert(c)

A primeira matriz contém os símbolos e a segunda matriz contém as letras mínimas necessárias para dizer a qual elemento está sendo referido. Agradecemos a core1024 e edc65 por ajudar a reduzi-lo. Teste em http://jsfiddle.net/xjdev4m6/2/ . Um pouco mais legível:

n=prompt().toLowerCase()
e='HyHeLitBeryBorCarNitFluNeonSoMagAlSiliPhSuChlArgPotCalcScTitVChrManIroCobNicCoppZinGalGeArsSelBrKRubStYttrZirNioMoTecRuthenRhoPaSilvCadInTinAnTelIoXCaeBaLanCePraNeodPromSaEuGadTerDyHoErThuYtteLuHafTaTuRheOsIriPlaGoMerThaLeBiPolAsRadoFrRadiAcThoProtUrNepPluAmCuBerkCaliEiFeMenNoLawRutherDuSeaBohHasMeiDaRoCopeUnuntFleUnunpLivUnunsUnuno'.match(x=/[A-Z][a-z]*/g).map(a=>a.toLowerCase())
s='HHeLiBeBCNFNeNaMgAlSiPSClArKCaScTiVCrMnFeCoNiCuZnGaGeAsSeBrKrRbSrYZrNbMoTcRuRhPdAgCdInSnSbTeIXeCsBaLaCePrNdPmSmEuGdTbDyHoErTmYbLuHfTaWReOsIrPtAuHgTlPbBiPoAtRnFrRaAcThPaUNpPuAmCmBkCfEsFmMdNoLrRfDbSgBhHsMtDsRgCnUutFlUupLvUusUuo'.match(x)
for(i=0;i<7;i++){
  if(c=s[e.indexOf(n.slice(0,i))]){
    alert(c,i=8) // i=8 breaks out of the loop so the result is only alerted once
  }
}
NinjaBearMonkey
fonte
Você pode economizar alguns bytes usando o fato de o Neo corresponder ao Neodímio, já que o Neon foi aprovado na lista?
7114 Dancrumb
1
@ Dancrumb Infelizmente não. O loop começa com a substring mais curta e, portanto, será atingido Neoantes de ser atingido Neonporque possui menos letras.
NinjaBearMonkey
1
+1 para o JS mais curto até agora. Embora você pode se livrar desta ifdeclaração (É uma perfeita forcondição) e também para inline ou mudar as posições de algumas variáveis, para encurtar o código;)
core1024
2
no início ).toLowerCase(-> )[L='toLowerCase'](, em seguida, no final a.toLowerCase(-> a[L](deve cortar 4 caracteres
edc65
10

Ruby 1.9+, 565 471 447 444

Um one-liner. Porque nada é "impossível de fazer com regexes" ...
(Apenas salvei 94 caracteres adicionando outra regex) ((e 24 simplificando-os))

p"VAlAmA.sArAcAnt|SbA.tBaB..kBeBiB.hBrBDyD.+sD.bE..sErEuF..mFrFlu|[email protected]|AuH.fH.sHeHoHInIro|FeIrIKrL.vL.+rLaLiLuL|PbM.gMoM.+dM.nM.+tM|HgC.+sC.dC.+fCeCar|[email protected]|CmCop|CuCoC.rC.lN.+dN.+pNeN..bNit|[email protected]|PdP...aPrP.uP..tPot|KPoPR.*n$RaR.+gR.eRhR.+bR.+fRuS.mScS.+gSeS..v|AgSiSo|NaS.rSTaT.cT.+bTeThu|TmT..lThTin|SnTiTu|WU.u.oU.u.pU.u.sU.u.tUXeY.+bYZ.nZ.r"
.split(/(?<!\|)(?=[A-Z])/).find{|r|/^#{r}/i.match *$*}.gsub /.*\||\W/,''

(nova linha após sequência adicionada para "legibilidade", remova para teste)

uso: ruby periodic.rb aluminum$>

Explicação:
Dividir a cadeia de caracteres nas maiúsculas iniciais retorna uma matriz de regex para corresponder aos nomes dos elementos. Os únicos caracteres alfabéticos permitidos em cada um são os da abreviação *. Eles são ordenados de forma que a primeira correspondência encontrada ao comparar com o argumento da linha de comandos *$*seja a correta. O gsub à direita retira os caracteres não-alfa antes da impressão.

* Abreviações estranhas como "Fe" para "Iron" são tratadas por um |elemento: "Iro | Fe". A primeira escolha é o que realmente corresponde; o gsub remove todos os caracteres até o '|', deixando a abreviação real.

Estrutura de teste (requer a lista do @ squeamish : baixada como 'table.txt' no diretório de trabalho).

def testfunc(name) 
  #replace with however you call your code
  return `ruby1.9.3 periodic2.rb #{name}`.chomp()
end

elements= File.new('table.txt').readlines.map{|s|s.chomp}

elements.each{|l|
  a,n=l.split(' ')
  r = testfunc(n)
  print "#{n} => #{a} "
  if r!=a then
    print ("FAIL: gave #{r}\n")
    exit
  else 
    print("\tOK\n")
  end
}
print("PASS: #{elements.size} elements matched\n")
AShelly
fonte
1
Ovação se ele funciona para todos os 100+ casos
edc65
Claro que funciona: ideone.com/7FZlAt
AShelly
Alguém tem a audácia de afirmar que algo não pode ser feito com regex. Obrigado por provar-los (um disse, muitos pensavam) errado :)
Mast
4

Ruby, 1068 bytes

require"zlib"
require"base64"
$><<eval(Zlib::Inflate.inflate(Base64.decode64"eJwlU8tu2zAQ/Bee+QW6CLYTx0FiR7CdtsmNkmhJCEUKfKQViv57Z9YnE+vd2ZnZ0d+1j2Go6oO2bipzpQ5W6SmPU6nU66S0jatzldqiGmLwVb3VJrZ87NAmoyf9Zx0sKm/alRCnqt5riw514lAvqCejtBm8TZU6Dgp984SGjcMuN3WhUhfsGkNaxqpudHG3Eqv6okdHPLVDXxwIuYmAzCalqn7RxnWkuQN2Z3yPxktH8sbjeQWg8QbV+oceY5iJE1kbDICOHpBE3JNka1zG3wHT3ZeF3hOmw7LYiGpB1XeV+sSIcY4rnwydmQn0hPmYLFduEqpOnhdWg4jcYmlclwyRL3iWdiLTc6s07PNYe0E15wjc+kNPsSOrT9Sm0HLXCZ3BrW0P0iBou9FbyIPSkkfYrs6F1vXsPY9C0aC36entNxVs4LjpZ/EKVX8/ybOnLqzHr8/TzCO0FODgvbreb4dV9bO2npx+oWSTzO6g1ER5bnlZn0eDvIgr9wbqN8kCtIEUG/qVKejFFQvRzYyx2fC6FzxLDAuej4VMg8PzqSeYOHAFrTUtEWAPK80QKQeYwf+B+4gVY5HLXGeaicFKfbS0yGaAvRL35mXsJnwNjnwF3+KHlKv6p4aV4iCIp1lQ3yAyTuLrMxY4k2lXk8kABm8KCXY06wCDR0YDmIiqFf+xfUpzgdYtw+QCc9GAdMqGnDZZtPKAzKLxHYp7JvR+nzNjjZVs7XjhKPpGWpgN8tgYGWNu3rVdcuEnt/DjykRtwG/GOdC5EYfvh5nJWjK+/WJYphts3d2YhZQRrMck0eauPXt9z95jz6/EUuEJEszvyOS9xnsIYcH5xmiLhQ9MkWkDqhcYE0YhvmU0U5ITcMWUGeMjTYgzTqAeUA3W5wFgHMPHhxU7prP4DLD3gmZnY/gGNSflxbIMzROCDnWv31JOUk7yDh3fQf37D7D/kWs="))[gets.downcase[1..5].to_sym]

Entrada via STDIN.

As subseqüências únicas mais curtas dos nomes dos elementos são do segundo ao sexto caractere (ou o final do nome, se for muito curto). Então, eu estou simplesmente pegando e pesquisando em um hash. Eu também compactou o hash porque isso economiza outros 200 bytes. Aqui está a aparência do hash:

{ydrog:?H,elium:"He",ithiu:"Li",eryll:"Be",oron:?B,arbon:?C,itrog:?N,xygen:?O,luori:?F,eon:"Ne",
 odium:"Na",agnes:"Mg",lumin:"Al",ilico:"Si",hosph:?P,ulfur:?S,hlori:"Cl",rgon:"Ar",otass:?K,
 alciu:"Ca",candi:"Sc",itani:"Ti",anadi:?V,hromi:"Cr",angan:"Mn",ron:"Fe",obalt:"Co",ickel:"Ni",
 opper:"Cu",inc:"Zn",alliu:"Ga",erman:"Ge",rseni:"As",eleni:"Se",romin:"Br",rypto:"Kr",ubidi:"Rb",
 tront:"Sr",ttriu:?Y,ircon:"Zr",iobiu:"Nb",olybd:"Mo",echne:"Tc",uthen:"Ru",hodiu:"Rh",allad:"Pd",
 ilver:"Ag",admiu:"Cd",ndium:"In",in:"Sn",ntimo:"Sb",ellur:"Te",odine:?I,enon:"Xe",esium:"Cs",
 arium:"Ba",antha:"La",erium:"Ce",raseo:"Pr",eodym:"Nd",romet:"Pm",amari:"Sm",uropi:"Eu",
 adoli:"Gd",erbiu:"Tb",yspro:"Dy",olmiu:"Ho",rbium:"Er",huliu:"Tm",tterb:"Yb",uteti:"Lu",
 afniu:"Hf",antal:"Ta",ungst:?W,heniu:"Re",smium:"Os",ridiu:"Ir",latin:"Pt",old:"Au",ercur:"Hg",
 halli:"Tl",ead:"Pb",ismut:"Bi",oloni:"Po",stati:"At",adon:"Rn",ranci:"Fr",adium:"Ra",ctini:"Ac",
 horiu:"Th",rotac:"Pa",raniu:?U,eptun:"Np",luton:"Pu",meric:"Am",urium:"Cm",erkel:"Bk",alifo:"Cf",
 inste:"Es",ermiu:"Fm",endel:"Md",obeli:"No",awren:"Lr",uther:"Rf",ubniu:"Db",eabor:"Sg",
 ohriu:"Bh",assiu:"Hs",eitne:"Mt",armst:"Ds",oentg:"Rg",opern:"Cn",nuntr:"Uut",lerov:"Fl",
 nunpe:"Uup",iverm:"Lv",nunse:"Uus",nunoc:"Uuo"}
Martin Ender
fonte
3

CJam, 462 449 434 401 391 384 382

Com a ajuda de Dennis.

Código

Ifs ternários aninhados provavelmente não são a maneira correta de fazer isso no CJam.

rel_"ruthen"#!"Ru"{_"tel"#!"Te"{__5{\_ceu\@=+_}:U~"PdYbRgCmCn"{\#)!}:X~{;__4U"RnPaCfDs"X{;_3U"NbCsNdPmTbPtTlBkEsFmMdLrMt"X{;2U"MgClCrMnZnAsRbSrZrTcCdSmGdHfReAtNpPuDbBhHsLv"X{;__"sili"#{;__ceu\1=@2=++"SodIroCopSilTinAntThuGolMerLeaTunPotRutSeaHydBorCarNitOxyFluPhoSulVanYttIodUra"\#3d/m[)"_NaFeCuAgSnSbTmAuHgPbWKRfSgHBCNOFPSVYIU"S%\=_"_"={;_1U"Un"={;4="Uu"\+}*}*}"Si"?}*}*}*}*}?}?]W=

Com recuos:

rel
_"ruthen"#!"Ru"
{
_"tel"#!"Te"
{
  __5{\_ceu\@=+_}:U~
  "PdYbRgCmCn"{\#)!}:X~
  {
   ;__4U
   "RnPaCfDs"X
   {
    ;_3U
    "NbCsNdPmTbPtTlBkEsFmMdLrMt"X
    {
     ;2U
     "MgClCrMnZnAsRbSrZrTcCdSmGdHfReAtNpPuDbBhHsLv"X
     {

       ;__"sili"#
       {
        ;__ceu\1=@2=++"SodIroCopSilTinAntThuGolMerLeaTunPotRutSeaHydBorCarNitOxyFluPhoSulVanYttIodUra"\#3d/m[)"_ Na Fe Cu Ag Sn Sb Tm Au Hg Pb W K Rf Sg H B C N O F P S V Y I U"S%\=_"_"=
        {;_1U"Un"={;4="Uu"\+}*}*
       }
      "Si"?

     }*
    }*
   }*
  }*
 }?
}?
]W=

Muitos dos símbolos são apenas as duas primeiras letras do nome do elemento. Eles são tratados na segunda camada mais profunda das instruções if aninhadas. Muitas outras são a primeira e a terceira letra, ou a primeira e a quarta letra - elas são tratadas em camadas externas sucessivas. Os símbolos onde apenas a primeira letra aparece e os irregulares completos são tratados na quinta e terceira camadas mais profundas, respectivamente.

Existem alguns onde fica confuso ( TelLuriumvs ThaLlium, ou SILiconvs SILver, ou RUTheniumvs RUTherfordium). Estes são tratados separadamente.

Muito golfe poderia ser feito aqui, principalmente reutilizando blocos de código e melhorando o manuseio de irregularidades.


fonte
1
Algumas dicas: 1. O comportamento para nomes de elementos inválidos pode ser indefinido, portanto, em vez de "RUTHENIUM"=você pode usá-lo "RUTHEN"#!. 2. Você não precisa imprimir explicitamente ( o) nem remover nada antes do nome real do elemento ( ;"Si"); basta anexar ]W=ao final do seu código para remover tudo, exceto o elemento de pilha mais alto. 3. Isso deixa alguns quarteirões vazios. Se Bfor um booleano, B{...}{}?e B{...}*consiga o mesmo. 4. O ternário se leva blocos ou elementos da pilha, de modo que você pode encurtar {"Si"}a "Si".
Dennis
@ Dennis Eu acho que você adicionou tudo isso na gestão pilha precisa de trabalho, embora -. Demais _e ;em todo o lugar
@ Dennis E eu raspado alguns personagens, alterando o caso padrão para minúsculas e usando os blocos de código alias mais
3

PHP, 507 485 476 466 caracteres

Uso: insira o nome do elemento como parâmetro GET '0' - elements.php? 0 = carbon

Algoritmo: Execute a sequência de dados, retirando substring, pares de códigos de abreviação. Se a substring corresponder ao início do elemento transmitido, use o código de abreviação para determinar o que produzir: Se o código começar com uma letra, produza-o como uma string. Se for um número N, imprima a primeira letra do elemento + a enésima letra. Os elementos Unun são diferenciados com o código '|'. Se nenhuma substring for encontrada que corresponda ao nome passado, imprima os dois primeiros caracteres do nome como abreviação.

Código legível:

<?
$l=ucfirst(strtolower($_GET[0]));
for(
  $m[3]="AnSbArs2As2Berk3Boh2BoBCad2Cae3Cali4CarCChl2Ch2Cope5CopCuCu5Da4Du2Ei3Fe3FluFGad2GoAuHaf2Ha2HyHIo0IroFeLaw3LePbLiv2Mag2Man2Mei3Men3MeHgNeod3Nep2Nio3NiNOxOPa5PhPPla3Plu2PotKProm3Pro4Rado4Rhe2Roe5Rub2Ruther6Sa2Sea6SilvAgSoNaSt2SuSTec2Ter3Tha3Thu6TinSnTuWUn|UUVVYtte5YYZin2Z2";
  preg_match('/(.[a-z]*)(.[a-z]*)(.*)/',$m[3],$m)
;)
    if(strstr($l,$m[1]))
        echo($x=$m[2][0])>'@'?$x>'{'?"Uu$l[4]":$m[2]:$l[0].$l[$x],die;
echo$l[0],$l[1];

Condensado:

<?$l=ucfirst(strtolower($_GET[0]));for($m[3]="AnSbArs2As2Berk3Boh2BoBCad2Cae3Cali4CarCChl2Ch2Cope5CopCuCu5Da4Du2Ei3Fe3FluFGad2GoAuHaf2Ha2HyHIo0IroFeLaw3LePbLiv2Mag2Man2Mei3Men3MeHgNeod3Nep2Nio3NiNOxOPa5PhPPla3Plu2PotKProm3Pro4Rado4Rhe2Roe5Rub2Ruther6Sa2Sea6SilvAgSoNaSt2SuSTec2Ter3Tha3Thu6TinSnTuWUn|UUVVYtte5YYZin2Z2";preg_match('/(.[a-z]*)(.[a-z]*)(.*)/',$m[3],$m);)if(strstr($l,$m[1]))echo($x=$m[2][0])>'@'?$x>'{'?"Uu$l[4]":$m[2]:$l[0].$l[$x],die;echo$l[0],$l[1];
Sir_Lagsalot
fonte
2

JavaScript (1100)

Implementação ingênua brilhando em sua simplicidade. Uma sub string única desde o início do nome é simplesmente mapeada para o símbolo.

e={hy:"H",he:"He",lit:"Li",bery:"Be",bor:"B",car:"C",nit:"N",ox:"O",flu:"F",neon:"Ne",so:"Na",mag:"Mg",al:"Al",sili:"Si",ph:"P",su:"S",chl:"Cl",arg:"Ar",pot:"K",calc:"Ca",sc:"Sc",tit:"Ti",v:"V",chr:"Cr",man:"Mn",iro:"Fe",cob:"Co",nic:"Ni",copp:"Cu",zin:"Zn",gal:"Ga",ge:"Ge",ars:"As",sel:"Se",br:"Br",k:"Kr",rub:"Rb",st:"Sr",yttr:"Y",zir:"Zr",nio:"Nb",mo:"Mo",tec:"Tc",ruthen:"Ru",rho:"Rh",pa:"Pd",silv:"Ag",cad:"Cd",in:"In",tin:"Sn",an:"Sb",tel:"Te",io:"I",x:"Xe",cae:"Cs",ba:"Ba",lan:"La",ce:"Ce",pra:"Pr",neod:"Nd",prom:"Pm",sa:"Sm",eu:"Eu",gad:"Gd",ter:"Tb",dy:"Dy",ho:"Ho",er:"Er",thu:"Tm",ytte:"Yb",lu:"Lu",haf:"Hf",ta:"Ta",tu:"W",rhe:"Re",os:"Os",iri:"Ir",pla:"Pt",go:"Au",mer:"Hg",tha:"Tl",le:"Pb",bi:"Bi",pol:"Po",as:"At",rado:"Rn",fr:"Fr",radi:"Ra",ac:"Ac",tho:"Th",prot:"Pa",ur:"U",nep:"Np",plu:"Pu",am:"Am",cu:"Cm",berk:"Bk",cali:"Cf",ei:"Es",fe:"Fm",men:"Md",no:"No",law:"Lr",ruther:"Rf",du:"Db",sea:"Sg",boh:"Bh",has:"Hs",mei:"Mt",da:"Ds",ro:"Rg",cope:"Cn",ununt:"Uut",fle:"Fl",ununp:"Uup",liv:"Lv",ununs:"Uus",ununo:"Uuo"}
n=prompt().toLowerCase()
for(i in e)n.indexOf(i)?i:alert(e[i])
Mika Lammi
fonte
2

Python - 652 649 637

Minha tabela de hash é baseada na combinação de cada segundo e terceiro caractere do nome em maiúsculas:

import re
def f(s,c='S<8F0FCE;2.ACR;J@W$;BI8>GD*?GnHQ<K>&T\(51IAg/Y?S2=169.,325(F(98?>?=^97DUCITX;SJ`0C<P9iLP/G4B,A(-A?(3QLLZ;81D(.4F;L8GaVP[=\=cOX3U,LQl6:E9/OXdSe(4,TSV/=FN98?K.18Q>R$+<GG[IS-4?;4H;T/IMq9<LXMYH4HG<>>KTT,>IIEM,[Nf<,:Z60(A9fImZTMRTcM?[lVg^qC}',e='HHeLiBeBCNOFNeNaMgAlSiPSClArKCaScTiVCrMnFeCoNiCuZnGaGeAsSeBrKrRbSrYZrNbMoTcRuRhPdAgCdInSnSbTeIXeCsBaLaCePrNdPmSmEuGdTbDyHoErTmYbLuHfTaWReOsIrPtAuHgTlPbBiPoAtRnFrRaAcThPaUNpPuAmCmBkCfEsFmMdNoLrRfDbSgBhHsMtDsRgCnUutFlUupLvUusUuo'):
 U=s.upper();X=lambda x:chr(32+sum(ord(u)-65for u in x))
 return re.findall('[A-Z][a-z]*',e)[zip(c[::2],c[1::2]).index((X(U[1::3]),X(U[:-1:2])))]

Aqui está o gerador correspondente:

table = '''
H     Hydrogen
He    Helium
...
Uuo   Ununoctium
'''

table = map(lambda l: l.split(), table.split('\n')[1:-1])

abbr = []
for name in map(str.upper, zip(*table)[1]):
    abbr.append(chr(32+sum(ord(u)-65 for u in name[1::3]))+
                chr(32+sum(ord(u)-65 for u in name[:-1:2])))
print 'c=' + ''.join(abbr)
print 'e=' + ''.join(zip(*table)[0])
print 'Unique' if len(table) == len(set(abbr)) else 'Duplicates'

Provavelmente, há espaço para melhorias, especialmente compactando as duas seqüências longas.

Testado com:

for short, name in table:
    if f(name) != short:
        print "Wrong result!"
Falko
fonte
2

Golfscript - 1052 821

{.91<32*+}%:x;'H
He
Li
Be
B
C
N
F
Ne
Na
Mg
Al
Si
P
S
Cl
Ar
K
Ca
Sc
Ti
V
Cr
Mn
Fe
Co
Ni
Cu
Zn
Ga
Ge
As
Se
Br
Kr
Rb
Sr
Y
Zr
Nb
Mo
Tc
Ru
Rh
Pd
Ag
Cd
In
Sn
Sb
Te
I
Xe
Cs
Ba
La
Ce
Pr
Nd
Pm
Sm
Eu
Gd
Tb
Dy
Ho
Er
Tm
Yb
Lu
Hf
Ta
W
Re
Os
Ir
Pt
Au
Hg
Tl
Pb
Bi
Po
At
Rn
Fr
Ra
Ac
Th
Pa
U
Np
Pu
Am
Cm
Bk
Cf
Es
Fm
Md
No
Lr
Rf
Db
Sg
Bh
Hs
Mt
Ds
Rg
Cn
Uut
Fl
Uup
Lv
Uus'n/'hy
he
lit
bery
bor
car
nit
flu
neon
so
mag
al
sili
ph
su
chl
arg
pot
calc
sc
tit
v
chr
man
iro
cob
nic
copp
zin
gal
ge
ars
sel
br
k
rub
st
yttr
zir
nio
mo
tec
ruthen
rho
pa
silv
cad
in
tin
an
tel
io
x
cae
ba
lan
ce
pra
neod
prom
sa
eu
gad
ter
dy
ho
er
thu
ytte
lu
haf
ta
tu
rhe
os
iri
pla
go
mer
tha
le
bi
pol
as
rado
fr
radi
ac
tho
prot
ur
nep
plu
am
cu
berk
cali
ei
fe
men
no
law
ruther
du
sea
boh
has
mei
da
ro
cope
ununt
fle
ununp
liv
ununs
ununo'n/[{x\?)}/]1?=

Explicação:

{        }%                              Map these ops to the input string:
 .91<32*+                                   Add 32 if less than 91 (convert to lowercase, in essence)
           :x;                           Store to x.
              '...'  '...'               The first array is the symbols, the second is the names.
                                         (stripped down to the minimum necessary)
                   n/     n/             Convert them to arrays.
                             {    }/     For each element in the name array...
                              x\?)          ...return 1 if the element is found in the input.
                            [       ]    Gather every element in an array...
                                     1?  Find the 1 in the array (the only element name match)...
                                       = ...then return that symbol in the symbol array.
                               (implied) Print.
Josiah Winslow
fonte
11
OMG, um pedaço de Golfscript que não tem 10 caracteres ou menos!
21814 WallyWest
1
Você pode obter uma grande melhoria para essa matriz de cadeias, utilizando uma corda com nova linha como separador e, em seguida, fazendon/
Peter Taylor
Eu fiz isso da última vez, por que diabos eu não pensei nisso? Atualizando agora.
Josiah Winslow
2

Haskell, 920 817 807 776 Caracteres

Depois de trabalhar muito tempo criando um sistema de regras para quais caracteres de um nome de elemento estão incluídos em seu símbolo e um pouco de ajustes, consegui escrever um script que traduz facilmente elemento em símbolo. O ferro era um problema para mim, porque eu pude amostrar certos caracteres de GOld, SilVer, TiN, LEAD, SoDium, MerCury, ANtimony, PotaSsium e TUngsten, convertendo-os em um símbolo periódico não utilizado (eu escolhi a amostragem que fosse mais fácil de integrar) nas regras existentes) e depois traduzindo após a conversão simbólica; O ferro, no entanto, era um problema, porque Ir, Io e In já são usados. Inicialmente, eram 920 caracteres, mas percebi que a correspondência final de padrões (a maior) não precisava estar lá, pois deixava as coisas passarem (que não eram) ou correspondia a todas elas; Portanto, Substituí-o por um curinga genérico. Depois disso, joguei de 817 a 808, abreviando alguns padrões usando caracteres curinga, de forma que eles ainda fossem exclusivos para o nome desse elemento (por exemplo, o único elemento com um 'w' em seu nome é Lawrencium, então "* w "corresponde a isso em 1 caractere a menos que" Lei ").

Aqui está o meu código. Testei-o para todos os elementos e codifiquei-o para que ele convertesse automaticamente sua entrada em titlecase, para não haver problemas com a distinção entre maiúsculas e minúsculas.

EDIT 1

Reduzi ainda mais a 776 caracteres, substituindo a expressão de caso em t por uma correspondência de padrão (isso faz sentido porque a expressão de caso estava testando o operando bruto em oposição a uma expressão em termos do operando), removendo parênteses desnecessários e retornando expressando ecomo uma sequência delimitada por nova linha em vez de uma lista de sequências, e posteriormente dividindo-a na função principal. Como essas mudanças são meramente golfe, deixei a versão legível por humanos inalterada.

import Data.Char
m _[]=True;m[]_=False;m k@(c:s)x@(y:z)=case y of{']'->m s x;'['->let(i,(_:j))=break(==']')z in(c`elem`i)&&m s j;'?'->m s z;'*'->null z||m k z||m s z||m s x;_->c==y&&m s z};p(a:t)(x:y)=case a of{'.'->x:p t y;'_'->p t y;_->a:p t y};p[]_=[];e="Iro\nUn\nCu Pa Ro Y*e\nR*r\n*pp\nCop Rado\nSea Thu\nCali Da P*ot Tha\nA*s Boh ?ub Ch [CG]ad [HM]a Liv Nep Plu Rhe S[ato] Tec Tin Z\nB*k Cae [ES]i *w Nio [FM]e N*d Pro Pla Ter\nBor Car Flu Hy Io Nit Ox Ph Su [UVY]\n*";s="Fe ._._. .____. .f .u .n ._____. .___. ._. .__. . ..";t"Sv"="Ag";t"Sd"="Na";t"Go"="Au";t"Le"="Pb";t"Mc"="Hg";t"An"="Sb";t"Ps"="K";t"Tu"="W";t"Tn"="Sn";t x=x;main=interact$unlines.map(\(a:b)->let y=toUpper a:map toLower b in t$p(snd.head.filter(any(m y).fst)$zip(map words$lines e)$words s)y).lines

Versão legível por humanos (novas linhas, espaçamento, nomes detalhados, comentários: 2311 caracteres)

import Data.Char

-- Test against search-pattern strings
match _ [] = True
match [] _ = False
match k@(c:s) x@(y:z) = case y of
']' -> match s x
'[' -> let (i,(_:j)) = break (==']') z in (c `elem` i) && match s j
'?' -> match s z
'*' -> null z || match k z || match s z || match s x
 _  -> c == y && match s z

-- Write according to name-pattern string
pattern (a:t) (x:y) = case a of
'.' -> x : (pattern t y)
'_' -> (pattern t y)
 _  -> a : (pattern t y)
pattern [] _ = []

-- Search-Patterns for the elements
elements=["Iro", -- Iron -> Fe
      "Un", -- UnUn-Blank-ium (1,3,5)
      "Cu Pa Ro Y*e", -- CuriuM PallaDium RoentGenium YtterBium (1,6)
      "R*r", -- Rutherfordium (1,f)
      "*pp", -- Copper (1,u)
      "Cop Rado", -- Copernicium Radon (1,n)
      "Sea Thu", -- SeaborGium ThuliuM (1,7)
      "Cali Da P*ot Tha", -- CaliFornium DarmStadtium ProtActinium PotaSsium (1,5)

      {- AsTatine ArSenic BoHrium DuBnium RuBidium ChLorine ChRome CaDmium
      GaDolinium HaFnium HaSsium MaNganese MaGnesium LiVermorium NePtunium
      PlUtonium RhEnium SaMarium StRontium SoDium TeChnetium TiN ZiNc
      ZiRconium (1,3) -}

      "A*s Boh ?ub Ch [CG]ad [HM]a Liv Nep Plu Rhe S[ato] Tec Tin Z", 

      {- BerKelium CaeSium EinSteinum SilIcon SilVer LawRencium NioBium
      FerMium MenDelevium MeiTnerium MerCury NeoDymium ProMethium PlaTinum
      TerBium (1,4) -}

      "B*k Cae [ES]i *w Nio [FM]e N*d Pro Pl Ter",

      {- Boron Carbon Fluorine Hydrogen Nitrogen Oxygen Phosphorous Sulphur
      Uranium Vanadium Yttrium (1) -}

      "Bor Car Flu Hy Io Nit Ox Ph Su [UVY]",
      "*"] -- Everything else (1,2)

-- respective naming patterns for searches
symbol = "Fe ._._. .____. .f .u .n ._____. .___. ._. .__. . .."

-- Translate fake symbols
translate x = case x of
"Sv" -> "Ag" -- SilVer
"Sd" -> "Na" -- SoDium
"Go" -> "Au" -- GOld
"Le" -> "Pb" -- LEad
"Mc" -> "Hg" -- MerCury
"An" -> "Sb" -- ANtimony
"Ps" -> "K" -- PotaSsium
"Tu" -> "W" -- TUngsten
"Tn" -> "Sn" -- TiN
  _  -> x  -- Keep everything else the same

main = interact $ unlines . map (\(a:b) -> let y = (toUpper a) : (map toLower b) in t $ p (snd.head.filter (any (m y) . fst) $ zip (map words e) $ words s) $ y) . lines

Se alguém estiver interessado em uma explicação para qualquer parte disso, não hesite em perguntar.

archaephyrryx
fonte
2

C # (826)

não é o melhor, mas pensei em tentar com o handicap do c #.

using System;class P{static string s="HyHHe1Li1Be1BoBCaCNitNOxOFlFNe1SoNaMaMgAl1Sil1PhPSuSChClAr1PotKCal1Sc1Tit1VaVChrCrManMnIrFeCo1Ni1CopCuZiZnGa1Ge1ArsAsSe1Br1Kr1RuRbStSrYtYZirZrNioNbMo1TecTcRut1Rh1PaPdSiAgCadCdIn1TiSnAnSbTel1IoIXe1CaeCsBa1La1Ce1Pra1NeoNdPrPmSaSmEu1GadGdTeTbDy1Ho1Er1ThTmYttYbLu1HaHfTa1TuWRheReOs1Iri1PlPtGoAuMeHgThaTlLePbBi1Po1AsAtRaRnFr1Rad1Ac1Tho1ProPaUrUNepNpPluPuAm1CuCmBerBkCaliCfEiEsFeFmMenMdNo1LawLrRuthRfDuDbSeaSgBohBhHasHsMeiMtDaDsRoRgCopeCnUnUutFle1UnuUupLivLvUnunUus",n,t,k;static void Main(){var d=new System.Collections.Specialized.StringDictionary();while(s!=""){k=g;d[k]=g;if(d[k]=="1")d[k]=k.Substring(0,2);};t=Console.ReadLine();while(t!=""&!d.ContainsKey(t))t=t.Remove(t.Length-1);Console.Write(d[t]);}static string g{get{n="";do n+=s[0];while((s=s.Remove(0,1))!=""&&s[0]>96);return n;}}}

Então, escrevi um programa para transformar o nome completo dos elementos (por exemplo, carbono) na menor, mas ainda única, string possível e fiz isso para todos os elementos com relação a todas as outras strings exclusivas. Eu, então, serializei isso em uma grande e feia cadeia de caracteres em que letras maiúsculas denotam o início de "pedaços", com pedaços alternando entre chaves e valores. Como KeyValueKey2Value2 etc.

Esse script desestiliza essa string grande e corta um caractere no final da string inserida até encontrá-lo no dicionário criado a partir da string grande.

(Devo acrescentar que meu conhecimento de C # não é incrível e o envio original que fiz foi apenas usar coisas que eu sabia, mas posteriormente tive alguns truques apontados por outras pessoas.)

miethpo
fonte
Você pode jogar isso ainda mais, alterando todas as definições de tipo para var. Você pode economizar um pouco mais removendo chaves depois de blocos de instrução única. Se você atribuir t.Substring(int, int)a um, Func<int, int, string>poderá salvar outro casal.
Brandon
Eu fiz a maioria das defs variáveis ​​"var", mas parece que perdi uma ou duas, também esqueci totalmente o ifs sem suporte, obrigado.
miethpo
Você pode raspar mais 5 caracteres por varing do string[] re mais 3 por varing o string t = Console...., por fim, você vai economizar 7 mais alterando return new string[]em return new[]no final.
Brandon
Existem várias outras pequenas melhorias que você pode executar, como mover sua if(...) break;lógica para as condições de saída do loop for. Várias outras inversões lógicas podem ser aplicadas, como do { } while(..)no método de extração. Isso é mais curto do que adicionar uma operação lógica separada para o caso de entrada. Publiquei uma edição no seu código que ainda precisa de revisão / aceitação devido ao meu baixo representante neste site. Reduziu para 870 caracteres.
Nicholas
1
@Nicholas Eu não estou certo de editar alguém do golfe código é educado ...
miethpo
1

JavaScript (E6) 1433

Aqui está um limite superior

F=n=>'0H0HYDROGEN0He0HELIUM0Li0LITHIUM0Be0BERYLLIUM0B0BORON0C0CARBON0N0NITROGEN0O0OXYGEN0F0FLUORINE0Ne0NEON0Na0SODIUM0Mg0MAGNESIUM0Al0ALUMINIUM0Si0SILICON0P0PHOSPHORUS0S0SULFUR0Cl0CHLORINE0Ar0ARGON0K0POTASSIUM0Ca0CALCIUM0Sc0SCANDIUM0Ti0TITANIUM0V0VANADIUM0Cr0CHROMIUM0Mn0MANGANESE0Fe0IRON0Co0COBALT0Ni0NICKEL0Cu0COPPER0Zn0ZINC0Ga0GALLIUM0Ge0GERMANIUM0As0ARSENIC0Se0SELENIUM0Br0BROMINE0Kr0KRYPTON0Rb0RUBIDIUM0Sr0STRONTIUM0Y0YTTRIUM0Zr0ZIRCONIUM0Nb0NIOBIUM0Mo0MOLYBDENUM0Tc0TECHNETIUM0Ru0RUTHENIUM0Rh0RHODIUM0Pd0PALLADIUM0Ag0SILVER0Cd0CADMIUM0In0INDIUM0Sn0TIN0Sb0ANTIMONY0Te0TELLURIUM0I0IODINE0Xe0XENON0Cs0CAESIUM0Ba0BARIUM0La0LANTHANUM0Ce0CERIUM0Pr0PRASEODYMIUM0Nd0NEODYMIUM0Pm0PROMETHIUM0Sm0SAMARIUM0Eu0EUROPIUM0Gd0GADOLINIUM0Tb0TERBIUM0Dy0DYSPROSIUM0Ho0HOLMIUM0Er0ERBIUM0Tm0THULIUM0Yb0YTTERBIUM0Lu0LUTETIUM0Hf0HAFNIUM0Ta0TANTALUM0W0TUNGSTEN0Re0RHENIUM0Os0OSMIUM0Ir0IRIDIUM0Pt0PLATINUM0Au0GOLD0Hg0MERCURY0Tl0THALLIUM0Pb0LEAD0Bi0BISMUTH0Po0POLONIUM0At0ASTATINE0Rn0RADON0Fr0FRANCIUM0Ra0RADIUM0Ac0ACTINIUM0Th0THORIUM0Pa0PROTACTINIUM0U0URANIUM0Np0NEPTUNIUM0Pu0PLUTONIUM0Am0AMERICIUM0Cm0CURIUM0Bk0BERKELIUM0Cf0CALIFORNIUM0Es0EINSTEINIUM0Fm0FERMIUM0Md0MENDELEVIUM0No0NOBELIUM0Lr0LAWRENCIUM0Rf0RUTHERFORDIUM0Db0DUBNIUM0Sg0SEABORGIUM0Bh0BOHRIUM0Hs0HASSIUM0Mt0MEITNERIUM0Ds0DARMSTADTIUM0Rg0ROENTGENIUM0Cn0COPERNICIUM0Uut0UNUNTRIUM0Fl0FLEROVIUM0Uup0UNUNPENTIUM0Lv0LIVERMORIUM0Uus0UNUNSEPTIUM0Uuo0UNUNOCTIUM'
.match(RegExp('([^0]+)0+'+n,'i'))[1]

Teste no console do FireFox / FireBug

F('Rutherfordium')

Resultado

Rf
edc65
fonte
1

SmileBASIC, 1763 1418 1204 1128 bytes

INPUT E$Hro$="H
Hiu$="He
Lhi$="Li
Byl$="Be
Bon$="B
Cbo$="C
Nro$="N
Oge$="O
For$="F
Nn$="Ne
Siu$="Na
Mne$="Mg
Ami$="Al
Sic$="Si
Psp$="P
Sfu$="S
Cor$="Cl
Aon$="Ar
Pas$="K
Cci$="Ca
Snd$="Sc
Tan$="Ti
Vad$="V
Com$="Cr
Mga$="Mn
In$="Fe
Cal$="Co
Nke$="Ni
Cpe$="Cu
Zc$="Zn
Gli$="Ga
Gma$="Ge
Aen$="As
Sen$="Se
Bmi$="Br
Kpt$="Kr
Rid$="Rb
Son$="Sr
Yri$="Y
Zco$="Zr
Nbi$="Nb
Myb$="Mo
Thn$="Tc
Rhe$="Ru
Rdi$="Rh
Pla$="Pd
Sve$="Ag
Cmi$="Cd
Iiu$="In
T$="Sn
Aim$="Sb
Tlu$="Te
Iin$="I
Xon$="Xe
Csi$="Cs
Biu$="Ba
Lth$="La
Pse$="Pr
Ndy$="Nd
Pme$="Pm
Sar$="Sm
Eop$="Eu
Gol$="Gd
Tbi$="Tb
Dpr$="Dy
Hmi$="Ho
Eiu$="Er
Tli$="Tm
Yer$="Yb
Let$="Lu
Hni$="Hf
Tta$="Ta
Tgs$="W
Rni$="Re
Oiu$="Os
Idi$="Ir
Pti$="Pt
Gd$="Au
Mcu$="Hg
Tll$="Tl
Ld$="Pb
Bmu$="Bi
Pon$="Po
Aat$="At
Ron$="Rn
Fnc$="Fr
Riu$="Ra
Ain$="Ac
Tri$="Th
Pta$="Pa
Uni$="U
Ntu$="Np
Pto$="Pu
Ari$="Am
Ciu$="Cm
Bke$="Bk
Cif$="Cf
Est$="Es
Fmi$="Fm
Mde$="Md
Nel$="No
Lre$="Lr
Dni$="Db
Sbo$="Sg
Bri$="Bh
Hsi$="Hs
Mtn$="Mt
Dms$="Ds
Rnt$="Rg
Cer$="Cn
Unt$="Uut
Fro$="Fl
Unp$="Uup
Ler$="Lv
Uns$="Uus
Uno$="Uuo
S$=VAR(E$[0]+MID$(E$,3,2))IF"Cm"==S$*!VAL(".1"+E$[1])THEN S$="Ce
IF LEN(E$)>12THEN S$="Rf
?S$

Eu escolhi três caracteres que eram em sua maioria únicos (o 0º, o 2º e o 3º), o que deixa dois casos especiais: Cerium / Curium são "Ciu" e Ruthenium / Rutherfordium são "Rhe". Para Ciu, verifico se o segundo caractere do nome é "e" ou "E" e, para "Rhe", verifico o tamanho do nome.

VAR(name)retorna a variável com esse nome. Os nomes de variáveis ​​não diferenciam maiúsculas de minúsculas.

12Me21
fonte
0

T-SQL, 900 894 676 bytes

SELECT ISNULL((SELECT LEFT(value,3)FROM
STRING_SPLIT('Sb An-As Ars-At Ast-Bk Berk-Bh Boh-B  Bor-Cd Cad-Cs Cae-Cf Cali-C  Car-Cl Chl-Cr Chr-Cn Cope-Cu Copp-Cm Cu-Ds Da-Db Du-Es Ei-Fm Fe-F  Flu-Gd Gad-Au Go-Hf Haf-Hs Has-H  Hy-I  Io-Fe Iro-Lr Law-Pb Le-Lv Liv-Mg Mag-Mn Man-Mt Mei-Md Men-Hg Mer-Nd Neod-Np Nep-Nb Nio-N  Nit-O  Ox-Pd Pa-P  Ph-Pt Pla-Pu Plu-K  Pot-Pm Prom-Pa Prot-Rn Rado-Re Rhe-Rg Ro-Rb Rub-Rf Ruther-Sm Sa-Sg Sea-Ag Silv-Na So-Sr St-S  Su-Tc Tec-Tb Ter-Tl Tha-Tm Thu-Sn Tin-W  Tu-UuoUnuno-UupUnunp-UusUnuns-UutUnunt-U  Ur-V  V-Yb Ytte-Y  Yttr-Zn Zin-Zr Zir'
    ,'-')m,t WHERE e LIKE SUBSTRING(value,4,9)+'%'),
(SELECT UPPER(LEFT(e,1))+LOWER(SUBSTRING(e,2,1))FROM t))

Os retornos são apenas para legibilidade, a segunda linha é uma sequência muito longa.

STRING_SPLIT é suportado no SQL 2016 e superior.

A entrada é obtida por meio de uma tabela preexistente t com o campo varchar e , de acordo com nossos padrões de IO . A saída é preenchida com espaços para 3 caracteres; as regras não estavam claras sobre se estava tudo bem. Se necessário, posso adicionar um TRIM.

A tabela de entrada é associada a uma tabela gerada com uma lista de todos os símbolos de elementos (preenchidos com 3 caracteres) com o prefixo exclusivo mais curto para cada nome de elemento ( Xé suficiente para o Xenon , mas o Rutherfordium exige Rutherdistingui-lo do Ruthenium ).

EDIÇÃO 1 : salvou 218 caracteres removendo as 44 entradas da lista cujo símbolo são as duas primeiras letras do nome; a ISNULLfunção é usada para verificar se a primeira consulta falha ao retornar uma linha e, em caso afirmativo, gera o símbolo (encaixado corretamente) a partir do nome do elemento de entrada.

BradC
fonte