Votre tâche - si vous l'acceptez - est d'écrire un programme qui aide à comprendre ma proposition sur les méta en calculant le gagnant d'une compétition code-golf-inversé . Bien sûr, les réponses à cette question seront traitées comme proposées, de sorte que votre programme (s'il est correct) puisse calculer si votre réponse deviendra la réponse acceptée.
Règles
- Le programme lit un fichier avec plusieurs lignes du format suivant (voir l'exemple ci-dessous): TAB [Language] [NumberOfCharacters] TAB [LinkToAnswer]
- Le nom de fichier est transmis comme argument à votre programme ou le fichier est redirigé vers l'entrée standard de votre programme. C'est votre choix, veuillez mentionner la méthode lors de la réponse
- Il est prévu que le format d'entrée soit correct. Il n'est pas nécessaire de traiter les erreurs.
- Le nombre de caractères est positif. Votre programme doit gérer des longueurs allant jusqu'à 65535. 64 Ko devraient être suffisants pour tout le monde :-)
- Le programme produit ces lignes sur une sortie standard qui répond à l'idée de la méta-proposition, c'est-à-dire
- le code le plus court d'un langage de programmation particulier gagne (phase de réduction)
- le code le plus long parmi tous les langages de programmation gagne (phase de tri)
- en cas d'égalité, toutes les réponses de même longueur doivent être imprimées
- L'ordre de sortie n'est pas important
- Bien que le code le plus long gagne, ce n'est pas du bowling . Votre code doit être aussi court que possible pour votre langage de programmation.
- Les réponses concernant rarement les langages de programmation qui n'essaient pas de raccourcir le code méritent un downvote, car ils essaient de contourner l'intention de ce genre de question. S'il n'y a qu'une seule réponse pour un langage de programmation spécifique, il serait considéré comme un candidat gagnant, vous pourriez donc commencer à souffler son code.
Exemple de fichier d'entrée (séparé par des onglets uniques en cas de problème de formatage):
GolfScript 34 http://short.url/answer/ags
GolfScript 42 http://short.url/answer/gsq
C# 210 http://short.url/answer/cs2
Java 208 http://short.url/answer/jav
C# 208 http://short.url/answer/poi
J 23 http://short.url/answer/jsh
Ruby 67 http://short.url/answer/rub
C# 208 http://short.url/answer/yac
GolfScript 210 http://short.url/answer/210
Sortie attendue (l'ordre n'est pas important):
C# 208 http://short.url/answer/poi
C# 208 http://short.url/answer/yac
Java 208 http://short.url/answer/jav
Mise à jour
Certains programmes reposent sur le fait qu'il existe un seul maximum (comme le programme de caractères C # 210). Dérivé de la réalité, quelqu'un peut également écrire un programme GolfScript avec 210 caractères. La sortie resterait la même. J'ai ajouté un tel GolfScript à l'entrée.
Update 2
Comme suggéré, j'ai repensé (toujours le code-golf aussi) et la date limite est le 2014-03-06 (qui ressemble à une date arbitraire, mais je serai de retour en Allemagne après avoir voyagé à ce moment-là).
Résultats finaux
J'ai décidé de voter comme suit:
- Les réponses où le nombre de caractères ne peut être confirmé obtiennent un commentaire pour expliquer le nombre.
- Les réponses qui peuvent être facilement réduites obtiennent un commentaire, une suggestion de modification et entrent dans le résultat avec la valeur de comptage la plus faible. (J'espère que je l'ai vu à l'avance).
- Les réponses qui ne compilent pas obtiennent un downvote. (Une tâche assez difficile en fin de compte).
- Les réponses qui ne sont pas jouées obtiennent un downvote (comme décrit dans les règles déjà).
- Les réponses qui produisent la sortie attendue obtiennent un vote positif. En raison de certaines réponses qui ne fonctionnent pas comme prévu, j'utilise 4 fichiers d'entrée différents et vérifie le résultat attendu.
Enfin, le gagnant est déterminé en fournissant le tableau des réponses qualificatives en entrée de mon programme de référence (plus une double vérification manuelle du résultat). Si ma propre réponse était la gagnante, je l'exclurais de la liste. En cas de plusieurs gagnants, je ne devrais en choisir qu'un. Par conséquent, certains bonus peuvent être gagnés:
- réponses qui acceptent plus de données que prévu (par exemple en dehors des plages définies)
- des réponses qui utilisent une idée intelligente de faire court
J'ai pris un instantané des réponses le 6 mars 2014, 19:45 UTC + 1. L'analyse est en cours. Vérifier toutes les réponses est plus difficile que prévu ...