Dada uma entrada em n
que 3 <= n <= 25
, execute as seguintes etapas, começando com um n
dado de um lado (faces no intervalo [1, n]
, inclusive):
- Imprima o resultado do lançamento dos
n
dados do lado atual em jogo, na forma kdn: X
(onde X
é o resultado e k
o número de dados em jogo).
- Se
X
for maior ou igual ao n/2
número de dados em jogo, adicione um dado. Senão, remova um dado.
- Se o número de dados em jogo for igual a
0
ou n
, pare. Senão, vá para a etapa 1.
Execuções de exemplo (observe que a saída entre parênteses é para explicação e não é necessária):
6 lados:
1d6: 4 (avg: 3.0, add)
2d6: 6 (avg: 6.0, add)
3d6: 9 (avg: 9.0, add)
4d6: 16 (avg: 12.0, add)
5d6: 13 (avg: 15.0, remove)
4d6: 9 (avg: 12.0, remove)
3d6: 5 (avg: 9.0, remove)
2d6: 7 (avg: 6.0, add)
3d6: 11 (avg: 9.0, add)
4d6: 14 (avg: 12.0, add)
5d6: 17 (avg: 15.0, add)
9 lados:
1d9: 7 (avg: 4.5, add)
2d9: 14 (avg: 9.0, add)
3d9: 18 (avg: 13.5, add)
4d9: 18 (avg: 18.0, add)
5d9: 28 (avg: 22.5, add)
6d9: 26 (avg: 27.0, remove)
5d9: 28 (avg: 22.5, add)
6d9: 34 (avg: 27.0, add)
7d9: 33 (avg: 31.5, add)
8d9: 30 (avg: 36.0, remove)
7d9: 29 (avg: 31.5, remove)
6d9: 35 (avg: 27.0, add)
7d9: 32 (avg: 31.5, add)
8d9: 42 (avg: 36.0, add)
Regras
- As saídas devem estar exatamente no formato
kdn: X
, com novas linhas separando cada rolo
- Você deve simular rolando vários dados; simplesmente
[1, n]
não é permitido retornar um número inteiro aleatório no intervalo (inclusive) multiplicado pelo número de dados atualmente em jogo, pois isso não simula com precisão o lançamento de vários dados.
- As brechas padrão são proibidas
- Isso é código-golfe , então a resposta mais curta em bytes vence
Entre os melhores
O snippet de pilha na parte inferior desta postagem gera o cabeçalho das respostas a) como uma lista da solução mais curta por idioma eb) como um cabeçalho geral.
Para garantir que sua resposta seja exibida, inicie-a com um título, usando o seguinte modelo de remarcação:
## Language Name, N bytes
onde N
está o tamanho do seu envio. Se você melhorar sua pontuação, poderá manter as pontuações antigas no título, identificando-as. Por exemplo:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Se você quiser incluir vários números no cabeçalho (por exemplo, porque sua pontuação é a soma de dois arquivos ou deseja listar as penalidades do sinalizador de intérpretes separadamente), verifique se a pontuação real é o último número no cabeçalho:
## Perl, 43 + 2 (-p flag) = 45 bytes
Você também pode transformar o nome do idioma em um link que será exibido no snippet:
## [><>](http://esolangs.org/wiki/Fish), 121 bytes
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="language-list"> <h2>Shortest Solution by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr> </thead> <tbody id="languages"> </tbody> </table> </div> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr> </thead> <tbody id="answers"> </tbody> </table> </div> <table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table><script>var QUESTION_ID = 65904; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 45941; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "https://api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>
Respostas:
Pitão, 37 bytes
Experimente online.
fonte
Mathematica,
958980 caracteresUngolfed
fonte
Echo
infelizmente não pode receber uma sequência de entradas comoPrint
faz.PHP,
164121112113109 bytesVersão final, eu prometo. Melhorado usando a sugestão de Titus:
EDIT: Adicionado um byte extra para formatação. Esqueceu que há um FI lá dentro que, graças à eliminação do texto "adicionar / sub", poderia ter sido um operador ternário:
A saída agora se parece com:
EDIT: Graças a @Manatwork, me salvou muito! Versão nova e melhorada:
Entrada anterior:
Rolos de matrizes separadas, produz isso:
E é assim chamado:
d(6, 1);
É obrigatório exibir o sufixo
Add
eSub
? Isso não está claro na sua pergunta.fonte
function d($x,$y=1){for($i=$y;$i--;)$r+=rand(1,$x);echo$y."d$x, $r↵";$r/$y>$x/2?$y++:$y--;if($y<$x&&$y)d($x,$y);}
$y-=$r/$y>$x/2?:-1
Python 3, 125
Economizou 3 bytes graças ao DSM.
Muito simples, lança um monte de dados e verifica a média. Nada muito chique aqui ainda.
Ele precisa ser chamado com um int. Então,
x(6)
produzirá algo como isto:.
fonte
JavaScript (ES6), 97
102106112bytesObrigado @ user81655 e @Jupotter por me salvarem alguns bytes.
Demo
Isso funciona apenas em navegadores compatíveis com ES6 (no momento que inclui Firefox e Edge, possivelmente com Chrome e Opera com os recursos experimentais de JavaScript ativados):
fonte
while
para umfor
loop, arredondar para baixo em|0
vez de~~()
e mover algumas instruções para remover os colchetes para economizar alguns bytes. Além disso, você pode torná-lo uma função anônima (nãof=
). 103 bytes:n=>{for(k=1;k&&k!=n;k+=x<k*n/2?-1:1)for(x=i=0;i++<=k;console.log(k+`d${n}: `+x))x+=1+Math.random()*n|0}
console.log
para o outrofor
loop (me custou 1 char a mais que o seu). Ainda assim,k&&k!=n
condição pela comparaçãok%n!=0
k%n
funciona ainda melhor;)CJam, 45 bytes
Experimente online.
Implementa as especificações literalmente (incluindo a fórmula matematicamente incorreta "mean roll"). Como esperado, a portabilidade do programa GolfScript original abaixo para CJam salvou um monte de bytes, devido à menor built-in nomes de comandos (
mr
,o
eg
em vez derand
,puts
edo
).GolfScript, 51 bytes
Aqui está minha entrada original do GolfScript. Truques de golfe notáveis incluem o uso do número
1
como uma variável convenientemente pré-inicializada para armazenar o número atual de dados a serem lançados. (Em vez dissoX
, a versão CJam usa , que CJam inicializa com o valor 1.)Ps. Vendo o título, originalmente eu queria responder isso em AnyDice . Mas acaba sendo uma escolha horrível para esse desafio, e não acho que seja tecnicamente possível usá-lo para implementar essa especificação, conforme determinado.
O problema é que AnyDice é uma linguagem específica de domínio para escrever programas determinísticos para calcular estatísticas de rolagem de dados. Embora a inspeção dos possíveis resultados de um teste e a execução de testes condicionais com base neles sejam possíveis por recursão, não há como gerar aleatoriedade real. Portanto, embora você possa simular essa sequência de lançamentos de dados no AnyDice, tudo o que você pode obter como resultado são estatísticas sobre coisas como, por exemplo, o número de lançamentos até o término do processo ou a distribuição dos resultados em uma determinada etapa.
Tudo isso dito, aqui está o mais próximo que eu poderia chegar do AnyDice :
Este não é um código particularmente válido, já que parecia um exercício de futilidade. Os truques de golfe de linguagem padrão, como encurtar nomes de funções e eliminar espaços em branco desnecessários, devem esgotar a maior parte do potencial de golfe.
O truque principal usado aqui é que, quando você chama uma função que espera um número (conforme indicado
:n
na definição de função) no AnyDice e passa um dado (ou seja, uma distribuição de probabilidade), o AnyDice avalia automaticamente a função para todo o possível valores do dado e combina os resultados em um novo dado.Aqui está uma captura de tela da saída (no formato de gráfico de barras) para os três primeiros rolos:
(Note-se que a coluna de "0" em cada gráfico indica a probabilidade de que a iteração parado, devido ao número de dados que batem quer 0 ou N, antes de o rolo de corrente. Isto acontece por ser uma forma conveniente para representar a condição de parada, pois é claro que rolar 0dN sempre produz 0.)
fonte
R, 103 bytes
Uma implementação bastante direta. Rolamentos de dados são feitos por
sum(sample(n,i))
.Execução de teste
fonte
CoffeeScript,
10699 bytesUngolfed
fonte
Julia, 77 bytes
A maior parte disso deve ser auto-explicativa - uma nova linha real está sendo usada na
print
string em vez de ser usadaprintln
para salvar um byte.rand(1:n,N)
produzN
números inteiros aleatórios entre 1 en
.fonte
Ruby,
939082 caracteresExemplo de execução:
fonte
QBIC , 83 bytes (não concorrente)
Explicação:
fonte
PHP, 104 bytes
Correr com
php -r '<code>' <N>
demolir
fonte