Código “atômico” de golfe - determine o número de nêutrons em um isótopo

9

Sua tarefa é pegar uma sequência que contenha um isótopo de um elemento como entrada, codificada como o exemplo a seguir com o número atômico seguido por um espaço e o símbolo químico IUPAC para o elemento:

162 Dy

e retorne o número de nêutrons em um átomo desse isótopo.

No exemplo acima, o disprósio-162 possui 96 nêutrons (162 nucleons totais, menos 66 prótons porque é disprósio), portanto a saída deve ser 96.

Você pode supor que o elemento fornecido será um dos 114 elementos atualmente nomeados permanentemente pelo IUPAC (incluindo flerovium e livermorium) e não um nome genérico como Uus"ununseptium". Você também pode supor que o número atômico do isótopo não exceda 1000 ou seja menor que o número de prótons no elemento.

Você não pode usar built-ins para recuperar dados sobre o número de elementos de prótons ou nêutrons, ou usar qualquer função em seu código que avalie uma string ou um token de número como código por si só.

O programa para usar o menor número de tokens para fazer isso em qualquer idioma vence. No entanto, para o objetivo deste desafio, todo caractere em uma string ou um nome de variável convertido em uma string conta como um token.

Lista de elementos e seu número atômico para referência:

Joe Z.
fonte
Ahaha certo, basta ler a tag wiki. Parece que eu não entendi o que a tag englobava.
Sp3000
11
Em geral, o código atômico do golfe é melhor do que o código do golfe em termos de equidade entre os idiomas, porque não favorece idiomas específicos para o golfe, como CJam ou Golfscript.
Joe Z.
2
Os números são considerados como token único? Como na minha resposta, é 65um único token ou 2 tokens?
Optimizer
4
"Em geral, o código atômico de golfe é melhor que o código de golfe em termos de equidade entre os idiomas, porque não favorece idiomas específicos para o golfe, como CJam ou Golfscript". Ou faz? ;)
Martin Ender
11
Se built-ins forem permitidos, a seguinte função, escrita no Mathematica, poderá ser usada:f[i_] := {n = ElementData[#[[2]], ToString@"StandardName"] <> ToString[#[[1]]], IsotopeData[n, "NeutronNumber"]} &[i]
DavidC 10/14

Respostas:

5

CJam, 120 6 ou 116 tokens

Se os números são de token único, temos o código inteiro como 6 tokens:

212065132249371573644124577121541653292994215804249878509033804566332949723850494006885998432589817663973272353884582668784347806472090795216938149345570424681103578762377771127645936569136562173556524971260383556793671988140498193154122873972644190003488894117491373991987567199279175132071186860926217964652052981868515510731685503564515183920386542420190587555479397630718313762477968862282786518176572529906744217608955037610524188966159703528812103601771438848515748286560373093942224945233978303729665751831532717 128b:c~

onde os tokens estão

212065132249371573644124577121541653292994215804249878509033804566332949723850494006885998432589817663973272353884582668784347806472090795216938149345570424681103578762377771127645936569136562173556524971260383556793671988140498193154122873972644190003488894117491373991987567199279175132071186860926217964652052981868515510731685503564515183920386542420190587555479397630718313762477968862282786518176572529906744217608955037610524188966159703528812103601771438848515748286560373093942224945233978303729665751831532717
128
b
:
c
~

Este código é equivalente ao código abaixo, que contém a versão em cadeia do grande número no código acima. Mas devido a uma string, o código abaixo tem 116 tokens:

ri"ᘭ᛭绊ڏ晍嬨塐弶⛡ᠸ庐ᖩે槑湘ࡊ㚋䊌栕ᄂỗ∘抁埵ໂČ槩唹ᘇ穗≧ṷ㴛勤烓≿Ⲳ㇭Ȋ嬅͙獚簜䱡数㍉㉦䩛爈拴矍㚴燌㾄䱮⃜⢴ⶏ㯗႒ݘ੡䅄瞟⮘㢧⳻⮵∼䚽珯ほֹ㳰櫣ݰ牜᫦殙ᆌ穟䖻ᄭⓚ獙஧༧撒咛啺"2F#b57b65f+:cr2*2<#2/)-

Tokens (com explicação) são

r                           "Read the first input";
i                           "and convert it to integer";
"
91 character string         "Then this base converted string";
"
2
F
#                           "'s ASCII representation of each character gets converted";
b                           "to base 2**15";
57                          "which gets converted to";
b                           "base 57";
65                          "and we add 65 to each element in the base 57 array";
f
+
:
c                           "and convert each array element to character.";
r                           "Then read the next input string, which is atom's IUPAC";
2                           "double it";
*
2                           "and take only first 2 characters";
<
#                           "Find the occurrence of these 2 characters in the big string";
2                           "and divide the index by 2";
/
)                           "increment the index to counter 0 offset";
-                           "and subtract this number, which is the atomic number from"
                            "the input number of nucleons";

Para executar a sequência acima, copie o código desse link, pois o SE remove alguns caracteres enquanto carrega a resposta.

Isso também pode ser reduzido para 109 tokens, mas o SE não me permite enviar minha resposta, lançando uma exceção de URI malformada.

A entrada é como

162 Dy

saída é como

96

A sequência estranha é apenas uma sequência codificada de base que contém todos os nomes IUPAC em seu Atomic number * 2 - 1índice.

Experimente online aqui

Optimizer
fonte
Por que os números não seriam um único token?
Martin Ender
@ MartinBüttner Bem, se para os fins desta pergunta, as seqüências de caracteres não são um token único, os números podem não ser muito :) :)
Optimizer
11
Isso dá errado os resultados para o boro e o índio, porque as letras de dois elementos começam com Be Iaparecem antes deles.
Martin Ender
^ Você quer dizer boro e iodo. Índio é In.
Joe Z.
Além disso, pessoal. Esse bug para B e eu é corrigido.
Optimizer
1

Python 3 com exec, 17 tokens

exec(int.to_bytes(42580960806925240587487231677747050990110980939298529158008049507419456038066480774222358994792932281429500848123044123619998194774734911333011516763318834841258668032468977581617546825403043048781904307873076644287421190283925612029151422009703963147720234582458918676020358978146687598642493196719470433413287097024943497230356536978257362073205770196031226838532057690859535911353521203287284228407660035870497366713816359382867026152168356178620422021081074864815228071041303891869741111572003521808946355179139580269537828514345177247630946236685801543450404664783011350766913659964138280312012942354586269107632396118108534925651704031851802293836135007879834261627022944650861299698061444211422731907625,295,'big'))

Python 3 sem exec, 35 tokens

m,n=input().split()
print(int(m)-(0x50000003c00000000000000000000000000000000000000000000000000000000000000000000000000000000008c00000000000000000000000000000000000000000000000000000000d80000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000116880005ad0000d002b832400000000000000000000000000000004c0000064f8000003806a0088015660000000000000000000000000000b00000000000ac0000000016efd12c0004b60000000000000000000000000000000000000000000000000000000000000000000000000000000000000000017a700760005400f400000000000001700a56c000000000000000000000000000004c0000000000000000000000000000000000000000000000000000000000000000002ee6000000000700000029e00522c0000000000000000000000000003680000002a3200000000000c00032800000000000000000000000000000e91c000ce000000000000000c000000000000e400000000000000000000000000000004800000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000009a000006200000000000000000000000000000000000000000000000000006c0000043000000000000509008000000000000000000000000000000000000000000000000000000000000082000007c0000000000000000000000000000000ae00000019390000000000068000000000000000000000000000000000fc06388000000000000000000000000000000000000000000000000108000000006e0000000000000000000000000000d2000000000000000000000000000074037300001be1808800000000c4e98000050000000000000000000000000000000046000000000061014f580001000000e0000000000000000000000000013eaa12400000017c680000002f0000059000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000009c04a2f7001000007880e0001300d408012000060a0000000000000000000>>7*int(n,36)&127))

Ruby com eval, 17 fichas

eval [22146635005300445083784033446026580324048447941091204274213253110537099437818224958820496527991920943430421799402248351995854377736142191462062582991150146209770141259010870255095388946677505144127700666745571877848513432112199556183753919673308110291261587736766001750331575554182707626697924148465335917814388410868486650419909619279250674754531982074694183257024218097391705830277480110741636037821082572926228904583257826932150641336017429157246896262085081972165351023141358378905645164343005169041637147077645200273099823888392038731180787177889720531999846231330677441270444855911286469030157575699579420898896870179419644019549285098577609138033580761786048462145007410.to_s(16)].pack('H*')

Javascript, 49 tokens

m=prompt().split(/ /);
alert(m[0]-(function(){
_H_He_Li_Be_B_C_N_O_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_
}).toString().split(/_/).indexOf(m[1]))

Apenas para ilustrar Count big-ints / symbols / variable como N tokens em atomic-code-golf :)

kennytm
fonte
Proibir evale exectrabalhar contra isso?
Joe Z.
@JoeZ. Ainda vulnerável ao ataque "tabela de pesquisa inteira grande", consulte a atualização.
Kennytm
Parece que esse problema foi mal formado desde o início, então.
Joe Z.
0

Javascript, 42 tokens (?)

alert(parseInt(x=prompt().split(" "))-Object.getOwnPropertyNames({__H_HeLiBeB_C_N_O_F_NeNaMgAlSiP_S_ClArK_CaScTiV_CrMnFeCoNiCuZnGaGeAsSeBrKrRbSrY_ZrNbMoTcRuRhPdAgCdInSnSbTeI_XeCsBaLaCePrNdPmSmEuGdTbDyHoErTmYbLuHfTaW_ReOsIrPtAuHgTlPbBiPoAtRnFrRaAcThPaU_NpPuAmCmBkCfEsFmMdNoLrRfDbSgBhHsMtDsRgCn__Fl__Lv:0})[0].indexOf(x[1])/2)

PS: Onde posso encontrar algum script para contar tokens?

Qwertiy
fonte