Il y a déjà eu un défi 9 trous (et un autre ici ), mais c'était tellement l'an dernier. Et d'ailleurs, je ne suis là que depuis 2 mois (bien que cela semble éternel). Et c'est considérablement différent.
Tableau des leaders: (notez que la pondération des trous n'est pas encore établie)
+---------------+------------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
|Competitor | Language | Hole 1 | Hole 2 | Hole 3 | Hole 4 | Hole 5 | Hole 6 | Hole 7 | Hole 8 | Hole 9 | Total |
+----------------------------------------------------------------------------------------------------------------------+
|Dennis |CJam | | 31 | | | | | | | | 31 |
+----------------------------------------------------------------------------------------------------------------------+
|Optimizer |CJam | | 35 | | | | | | | | 35 |
+----------------------------------------------------------------------------------------------------------------------+
|Martin Büttner |Mathematica | | 222 | | | | | | | | 222 |
+----------------------------------------------------------------------------------------------------------------------+
|Cameron |Python | 878 | | | | | | | | | 878 |
+----------------------------------------------------------------------------------------------------------------------+
|bubalou |Processing 2| 717 | | | | | | | | | 717 |
+----------------------------------------------------------------------------------------------------------------------+
|Doorknob |Python 2 | | |0.079711| | | | | | |0.079711|
+----------------------------------------------------------------------------------------------------------------------+
|Vulcan |Java | | |0.6949 | | | | | | |0.6949 |
+----------------------------------------------------------------------------------------------------------------------+
|Eli |C++ | | |1.42042 | | | | | | |1.42042 |
+---------------+------------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
Autres trous:
Il a été lent ici ces derniers temps, donc je suis ici pour lancer le prochain parcours de golf de 9 trous, impliquant une poignée de tout ce que j'ai vu ici dans mon expérience (bien que limitée). Cela impliquera:
- Art Ascii
- Sortie graphique
- Le jeu de la vie de Conway
- roi de la colline
- Complexité de Kolmogorov
- Quines
- Traitement d'image
- Math
- Golf de code classique.
J'ai vraiment hâte de voir ce que vous pouvez faire!
Règlement du concours
- Vous choisirez 1 langue pour tous les trous (auxquels vous participez ... voir point 4 pour plus d'informations).
- Pour tous les trous - les failles standard ne sont (toujours) pas drôles.
- Le prochain défi apparaîtra lorsque je constaterai qu'il y a suffisamment de soumissions compte tenu d'un délai raisonnable. Le roi de la colline, par exemple, prendra plus de temps.
- Vous n'êtes pas obligé de participer à tous les trous. Si vous trouvez un trou particulièrement difficile, n'avez pas le temps de le faire, etc., vous recevrez 2 fois plus de points que le score le plus bas. Veuillez ne pas profiter de cette règle en laissant 1 réponse golfscript avec 12 caractères et en prenant 24 comme score.
Notation
- Votre score est basé sur le point culminant des scores de tous les trous
- Le score le plus bas gagne (selon le vrai golf)
- Le classement sera placé en haut de cette page
Je ferai de mon mieux pour m'assurer qu'aucune question n'est en double, que toutes les questions ont des critères objectifs, qu'elles sont bien écrites et qu'elles ont toutes (relativement) le même poids dans le contexte de l'ensemble du concours.
Cependant, veuillez être patient lorsque j'échoue.
Et, sans plus attendre, le premier défi!
Le globe de plasma
Un globe plasma est le jouet préféré de tous:
Votre travail consiste à en dessiner un.
Vous devez dessiner une base:
un globe:
Un truc Tesla (?)
Et, bien sûr, des pousses de plasma cool:
Cependant, lorsque vous placez votre main près d'un globe de plasma (ou d'un objet conducteur comme Wikipedia me le dit), il attire le plasma .
Votre globe devrait refléter cela.
Pour le dire quantitativement, votre globe a un maximum de 16 pousses (voir l'image ci-dessus). Un «objet» à la surface du globe (donné par un angle en radians) contiendra une «puissance conductrice», c'est-à-dire la quantité de faisceaux qu'il attire. Ainsi, un objet d'une puissance de 5 attirera 5 faisceaux (une seule ligne avec une épaisseur de 5), laissant 11 se répartir uniformément sur le reste du globe :
Notez que
1. le cercle noir au milieu reste au-dessus du plasma
2. que dans cet exemple, l'angle serait pi / 2.
Vous pouvez avoir plus d'un objet conducteur, et dans ce cas, il n'est pas nécessaire que les pousses soient également espacées. Cependant, ils doivent être relativement espacés. Par exemple, cela est correct pour 2 objets, 1 à l'angle pi / 4 puissance 5 et un autre à l'angle 5pi / 3 puissance 3:
Vous devriez pouvoir voir chacun des points d'extrémité des pousses (de plasma).
Cependant, étant donné un objet (ou une somme d'objets) avec une puissance supérieure à 16, le globe "se brisera":
Remarques
- Le diamètre du globe est 1,5 fois plus grand que la longueur de la base, qui est un carré
- Lorsque le globe se brise, le globe est sur le côté droit. Il est tangent au côté droit de la base ainsi qu'au sol. Il ne devrait pas y avoir de plasma lorsque le globe de plasma est cassé (pourquoi? Caractéristiques de sécurité bien sûr! Aucun mot sur la façon dont il s'est cassé en premier lieu.)
- La couleur de tout sauf les pousses doit être noire et d'une épaisseur de 1 pixel. La couleur du plasma a une teinte 245 - 280, et une saturation / valeur 100. Utilisez ceci sous "HSV" si vous ne savez pas de quoi je parle.
Contribution
L'entrée peut se faire via STDIN / arguments de ligne de commande / quoi que ce soit ou via des arguments de fonction.
Il devrait y avoir 2 entrées - longueur de la base du globe plasma (inclure un axe si vous utilisez des graphiques vectoriels), et un tableau d'objets comme celui-ci:
[[angle,power],[angle,power],[angle,power]]
Donc, pour aucun objet (voir la première image avec 16 lignes), l'entrée serait
100,[]
Pour le suivant (un objet, puissance 5) ce serait:
100,[[1.570796,5]]
Pour le dernier exemple:
100,[[0.785398,5],[5.23598,3]]
C'est le code-golf, donc le code le plus court en octets l' emporte.
la source
-3/8π
? Dans ce cas, il chevaucherait exactement l'un des autres faisceaux. Faut-il faire tourner tous les faisceaux dans un tel cas? Si c'est le cas, je pense que vous devez spécifier la distance entre les faisceaux individuels et les faisceaux induits par l'objet.Réponses:
Traitement de 2 à 717 caractères
Comme le traitement est un langage fait pour les artistes et que je suis un programmeur très novice, je ne m'attends pas à réussir très bien sur plusieurs de ces défis. Cela étant dit, j'aime vraiment à quel point il est simple de dessiner des choses dans le traitement, et j'ai voulu jouer encore avec, donc ces défis devraient être intéressants.
Je suis sûr que cela peut être considérablement minimisé et je peux essayer de le faire quand j'aurai plus de temps, mais pour l'instant j'en suis satisfait.
lit dans un fichier (f.txt) situé dans le dossier de données de l'esquisse pour obtenir son entrée. J'ai utilisé l'idée de Camerons de déplacer les faisceaux libres jusqu'à ce qu'ils ne se chevauchent pas.
Exemples:
100, [[0,785398,3], [5.23598,5]]
100, []
100, [[1.72398,12], [5.23598,5]]
obtenez le traitement ici
la source
Python, 878 caractères
Ce n'est pas du tout bien joué au golf, mais je voulais voir une réponse pour ce trou.
Et quelques exemples de sorties
la source
A,B=zip(*C)
devrait économiser quelques octetsPython 2.7,
378375Il lit ses paramètres à partir de l'argument de ligne de commande.
Exemples d'images:
(paramètres =
100,[[0.785398,5],[5.23598,3]]
)(paramètres =
100,[]
)(paramètres =
100,[[1.72398,12],[5.23598,5]]
)la source