Introdução
Para quem quer saber exatamente o que é o Befunge , é uma linguagem bidimensional baseada em pilha, criada em 1993 por Chris Pressy. Fiz 7 quebra-cabeças que precisam ser resolvidos no Befunge-93 . Este é um desafio bastante experimental, mas achei que vale a pena tentar :). Uma lista completa de todos os comandos usados no Befunge-93 pode ser encontrada aqui .
Como jogar?
A tarefa é um pouco como policiais e ladrões sem os policiais. É basicamente quebrar as submissões para ganhar pontos. Todo quebra-cabeça contém pontos de interrogação. Eles devem ser substituídos por qualquer caractere ascii imprimível no intervalo 32 - 127
, que inclua espaço em branco. Veja o seguinte exemplo:
??????@
Dado é que a saída deve ser hi
. Após algumas intrigantes, podemos descobrir que a solução foi:
"ih",,@
Mas! Você não dá a solução. Isso é para a prevenção de trapaça. Você não publica a solução, mas o hash . O hash é gerado com o seguinte snippet:
String.prototype.hashCode = function() { var namevalue = document.getElementById("inputname").value; var namenumber = 123;for (var character = 0; character < namevalue.length; character++) {namenumber += namevalue.substring(0, 1).charCodeAt(0);}var hash = 123 + namenumber, i, chr, len;if (this.length === 0) {return 0;}for (i = 0, len = this.length; i < len; i++) {chr = this.charCodeAt(i);hash = ((hash << 5) - hash) + chr; hash |= 0; }hash = Math.abs(hash);if ((hash).toString(16).length < 20) {for (var rand = 123; rand < 199; rand++) {hash = hash * rand;if ((hash).toString(16).length >= 20) { break; }}}return (hash).toString(16).substring(2, 12);};function placeHash() { var pretext = document.getElementById("inputhash").value; var resultinghash = pretext.hashCode(); document.getElementById("resulthash").innerHTML = 'Your hash: <span class="hashtext">' + resultinghash + "</span>";}
p {font-family: monospace;color: black;} .hashtext{color: red;font-weight:bold}
<div class="container"><p>Personal hash generator:<p><textarea id="inputhash" placeholder="Your submission" cols="40" rows="4"></textarea><br><textarea id="inputname" placeholder="Your name" cols="40" rows="1"></textarea><br><button class="hashbutton" onclick="placeHash()">Generate Hash!</button><br><p id="resulthash">Your hash:</p></div><!-- Created by Adnan -->
Como usar o snippet?
- Primeiro, cole a solução na seção de envio
- Segundo, digite seu nome de usuário (nada mais, isso será verificado depois do prazo)
- Terceiro, pressione Gerar Hash! para obter seu hash pessoal .
- Copie e cole o hash no seu envio.
Os quebra-cabeças
Quebra-cabeça 1 (Pontuação: 3)
??
??? ?
??????????
@
Saída (observe o espaço em branco à direita):
1 2 3 4 5 6 7 8 9 10
Quebra-cabeça 2 (Pontuação: 3)
???? ?
??????????
?? ?
@
Resultado:
abcdefghijklmnopqrstuvwxyz
Quebra-cabeça 3 (Pontuação: 5)
?????????
????? ???
? ?
? ? ? ?
?
? ?
?????? ? ?
? ? ?
? ? @
??????? ?
? ?
???? ??
? ??
Resultado:
Hello World!
Quebra-cabeça 4 (Pontuação: 2)
??????@
Saída (observe o espaço em branco à direita):
123
Quebra-cabeça 5 (Pontuação: 5)
?
?????
???@?????
??????
?????????
Resultado:
Befunge
Quebra-cabeça 6 (Pontuação: 5)
? ? ?
?
??????????
?
?
???????? ??????????????
?????"floG edoC dna selzzuP gnimmargorP "??????
@
Resultado:
###################################
Programming Puzzles and Code Golf
###################################
Quebra-cabeça 7 (Pontuação: 3)
???? ?????
???????
@???????
Resultado:
012345678910
- Este é um desafio de código , a pessoa com a maior quantidade de pontos ganha!
- Em caso de empate, a pessoa que enviou todas as inscrições primeiro vence.
- O último dia para envio é 10 de janeiro UTC . Depois disso, você tem 2 dias para postar a solução completa, com os hashes já incluídos. Estes serão verificados :).
Como postar?
Use o seguinte snippet para postar seu envio:
#N solutions:
Puzzle 1: `[hash 1]`
Puzzle 2: `[hash 2]`
etc.
Não é necessário resolver os quebra-cabeças em ordem. Todos os programas foram testados aqui e serão usados para verificação.
Boa sorte!
?
)?