<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 = 66763; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 38512; 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>
n
est (implicitement, je vous l'accorde) limité à [1,6], donc 100 est sorti.Réponses:
Pyth, 23 octets
Vraiment simple. Un nombre aléatoire d'itérations de 0 à 5 affiche le clic et demande une ligne d'entrée, suivie d'un coup à la fin.
la source
*BANG!*
, pasBANG
Rubis, 51 octets
Ungolfed:
ou
Ungolfing est parti pour les lecteurs. Pas si difficile
$><<
commeputs
remplaçant."*click*"
sont correctes (ce qui est requis est imprimé à la fin), en remplaçant$><<
parp
. Je ne savais pas si cela respecterait toujours les règles.6864 octets(une autre approche)
Je n'ai pas beaucoup réfléchi à l'algorithme (il peut être encore plus compact, mais pas si clair), mais j'aime vraiment le modèle qu'il contient:
0
est une balle. D'autres chiffres ne le sont pas.find
trouve une première valeur de retour pour laquelle le bloc n'est nifalse
ninil
.||
-expression est implicitement renvoyée par le bloc. C'est un court-circuit: il retourne son premier opérande (sauf si c'estnil
oufalse
) ou un second (sinon). Il renvoie donctrue
(six<1
ou, plus clair mais plus longx == 0
) ou la valeur de retour deputs
, tandis que ...puts
revient toujoursnil
. Oui.gets
demande une entrée. Il Entersuffit de frapper .la source
JavaScript, 64 octets
Explication
Pour tirer sur la gâchette, entrez n'importe quel texte dans l'invite. N'entrez rien ou cliquez sur Annuler pour terminer.
la source
"*Bang!*"
n'est pas supérieur à 7. MaisNaN
n'est pas inférieur à 7.Lua,
8275 octetsAssez long, mais il y a beaucoup de verbeux dans lua.
la source
LabVIEW, 46 primitives LabVIEW
Crée un tableau de 0 et un 1, a une boucle pour attendre les clics et sort la chaîne. Il indique initialement que BANG parce que j'ai oublié de réinitialiser l'indicateur avant de le démarrer.
Notez également que c'est un gif, si si ne joue pas / charge pour vous, veuillez rouvrir la page.
la source
"*click*"
sortez au cas où l'arme ne tirerait pas. De plus, est-ce que ça sort"bang"
ou"*BANG!*"
?Pyth,
313028 octetsPeut presque certainement être amélioré. Entrez un nombre quelconque pour tirer sur la gâchette, une entrée vide pour terminer plus tôt (avec une erreur).
Explication:
la source
"
.FN<any>
est toujours entièrement identiqueV<any>
, qui devrait probablement être changé pour ne pas confondre les nouveaux golfeurs ...: P.?
. Il n'y a pas besoin d'unelse
.Sérieusement,
2725 octetsPas de lien en ligne car il n'y a aucun moyen de faire une invite avec une entrée canalisée. Le programme peut être CTRL-C'D à tout moment de
pouletfin.Explication:
la source
PHP, 52 octets
Nécessite l'
-F
option de ligne de commande, comptée comme trois. La gâchette est tirée en appuyant sur Enter.Parce que
-F
court littéralement le script à nouveau pour chaque entrée (enfant , je vous pas),die
et autres ne se terminera pas en fait, donc nous sortir par erreur d'exécution supprimée à la place,@\n
.Exemple d'utilisation
la source
Perl 5, 43 octets
Courez avec
perl -p
. Variante de balle stable - c'est-à-dire que la position de la balle n'est décidée qu'une seule fois au tout début.la source
//=
. N'oubliez pas non plus de compter-p
dans votre score .C,
1107472 octetsMerci à Dennis de se débarrasser des inclusions et de beaucoup moins d'octets.
la source
Candy , 36 octets
Environ la moitié du programme est le texte à imprimer :(
forme longue:
la source
Python 3, 95 octets
Aussi ma première tentative de golf, également en Python 3. Je jure que Bruce et moi ne sommes pas la même personne.
Ungolfed:
Générez un nombre aléatoire entre 0 et 5 inclus, imprimez le clic autant de fois, puis imprimez le bang . Appuyez sur entrée / retour pour tirer sur la gâchette.
la source
from random import*
PlatyPar ,
2625 octetsExplication:
Essayez-le en ligne !
la source
Emacs Lisp,
9489 octetsUngolfed:
la source
R,
868077 octetsComme d'habitude, R a des fonctionnalités impressionnantes pour coder le golf mais des noms de fonction looooooong.
la source
Python 2,
10810410210098 bytesMa première tentative de golf:
Je devrais peut-être ajouter que le programme ne se termine pas correctement lorsque vous perdez, il lève juste une exception (ce qui entraîne la résiliation):
la source
a=shuffle([1,0,0,0,0,0])
wc
cela me donne 109 qui de trop, donc c'est vrai. Comment comptez-vous?Perl 5, 40 octets
Exécuter sans options de ligne de commande, le déclencheur est tiré en appuyant sur Enter.
la source
Python, 81 octets
inspiré des solutions Ruby (51) et Python
la source
Lisp commun, 109
Pas très compétitif, mais j'aime les listes circulaires:
la source
Perl 5, 43 octets
42 octets +
-p
option de ligne de commande. Appuyez simplemententer
pour déclencher.Merci à Dom Hastings pour son aide! La réponse d'origine était 67 octets:
la source
-p
était qu'il se terminerait avant d'appeler la dernièreprint
instruction, sans savoir pourquoi. Je l'ai essayé. A part ça, de super suggestions, merci! Mes connaissances continuent de croître ...0|
astuce n'a pas fonctionné comme prévu, mais j'en ai rasé quelques octets, l'instruction print et la dernière instruction comme vous l'avez suggéré. À quoi ça ressemble maintenant?MATL , 41 octets
Pour tirer sur le déclencheur, saisissez une chaîne non vide (telle que
'try'
).Pour terminer, entrez une chaîne vide
Exemples
Dans ce cas, la gâchette a été actionnée une fois et ... pas de chance:
Dans ce cas, l'utilisateur s'est arrêté (notez la dernière entrée vide) après deux tirages chanceux:
Explication
la source
Perl 6 ,
5853 octetsAppuyez sur Entrée pour tirer sur la gâchette, ou sur Ctrl + C pour la poser.
la source
Python 2,
8884 octetsCette solution est inspirée des solutions python 3 déjà données. J'ai choisi python 2 pour supprimer la parenthèse d'impression même si cela change le comportement de input ().
la source
Rubis, 45 + 1 = 46
Pas aussi intelligent que le côté D mais légèrement plus court.
Avec l'indicateur de ligne de commande
p
, exécutezL'utilisateur peut appuyer sur la gâchette avec retour et repartir avec control-c.
p
entraîne l'exécution du programme en boucle, la lecture des lignes depuis STDIN et la sortie$_
. Chaque fois qu'il s'exécute, il s'incrémente$.
. Ainsi, lors de la première exécution, il choisit un entier positif aléatoire inférieur à 6, puis 5, puis 4, etc. Sur le premier 0, nous sortons manuellement et quittons, jusque-là nous sortons implicitement.(et maintenant je remarque qu'il y a déjà un Perl très similaire. Oh bien.)
la source
Perl 5,
695149 octetsIl y a probablement un peu plus de potentiel pour le golf, je vais y réfléchir.
Changements:
$l
certains points-virgules et 10 octets en passant<STDIN>
à<>
la source
map{<>;print"*click*"}1..rand 6;<>;print"*BANG!*"
VBA, 126 octets
Version Golf pour octets minimaux
Version amusante qui rend les boutons plus clairs pour une meilleure acceptation des utilisateurs.
Du plaisir avec les formulaires personnalisés et vous pourriez faire un joli jeu Slick en VBA.
la source
APL, 39/65 octets
Réponse assez simple.
la source
C, 180 octets
Ma première tentative de golf de code, il y a probablement beaucoup de place pour l'amélioration :)
la source
Julia, 71 octets
Appuyez sur Enterpour tirer ou sur Ctrl+ Cpour quitter. Ce dernier se termine par un
InterruptException
.Ungolfed:
la source
Lua, 73 octets
la source