Art ASCII du jour # 4 - Signes du zodiaque

12

Nous aimons tous les horoscopes, n'est-ce pas ? Mais j'ai un grave problème dans cette application Horoscope installée sur mon téléphone intelligent car elle n'affiche que l'icône du signe du zodiaque pour l'horoscope de chaque jour. Maintenant, je me souviens de mon horoscope, mais il est difficile de se souvenir des autres dont l'horoscope m'intéresse.

Défi

Voici donc votre défi pour un autre ajout à la série ASCII Art of the Day. Étant donné une entrée de date et de mois, sortez le signe du zodiaque correspondant au format ASCII comme indiqué ci-dessous. Chaque signe du zodiaque est suivi après le nom et la plage de dates ( DD MMformat) du signe du zodiaque.

Aries - 21 03 - 20 04
 .-.   .-.
(_  \ /  _)
     |
     |
Taurus - 21 04 - 20 05
 .     .
 '.___.'
 .'   '.
:       :
:       :
 '.___.'
Gemini - 21 05 - 20 06
._____.
  | |
  | |
 _|_|_
'     '
Cancer - 21 06 - 20 07
   .--.
  /   _'.
 (_) ( )
'.    /
  '--'
Leo - 21 07 - 20 08
  .--.
 (    )
(_)  /
    (_.
Virgo - 21 08 - 20 09
 _
' ':--.--.
   |  |  |_
   |  |  | )
   |  |  |/
        (J
Libra - 21 09 - 20 10
     __
___.'  '.___
____________
Scorpio - 21 10 - 20 11
 _
' ':--.--.
   |  |  |
   |  |  |
   |  |  |  ...
         '---':
Sagittarius - 21 11 - 20 12
      ...
      .':
    .'
'..'
.''.
Capricorn - 21 12 - 20 01
        _
\      /_)
 \    /'.
  \  /   :
   \/ __.'
Aquarius - 21 01 - 20 02
.-"-._.-"-._.-
.-"-._.-"-._.-
Pisces - 21 02 - 20 03
'-.    .-'
   :  :
 --:--:--
   :  :
.-'    '-.

Contribution

  • Vous recevrez deux nombres entiers correspondant à la date du mois et du mois de l'année (dans cet ordre) de l'anniversaire.
  • La date et le mois seront 1indexés comme dans les calendriers normaux.
  • Vous pouvez prendre la forme d'entrée STDIN / ARGV / fonction arguments ou l'équivalent le plus proche

Production

  • Sur la base de quelle plage de dates la date d'entrée tombe, sortie vers STDOUT, le signe du zodiaque correspondant.
  • Vous pouvez avoir jusqu'à 4 espaces de fin dans chaque ligne, mais aucun espace de début qui ne fait pas partie de la sortie.
  • Vous pouvez soit écrire un programme complet ou une fonction nommée.

C'est du donc le code le plus court en octets gagne!


Classement

Le premier post de la série génère un classement.

Pour vous assurer que vos réponses s'affichent, veuillez commencer chaque réponse par un titre, en utilisant le modèle Markdown suivant:

# Language Name, N bytes

Nest la taille de votre soumission. Si vous améliorez votre score, vous pouvez conserver les anciens scores dans le titre, en les barrant. Par exemple:

# Ruby, <s>104</s> <s>101</s> 96 bytes
Optimiseur
la source
1
Connexe: codegolf.stackexchange.com/q/35036/29750
NinjaBearMonkey
@NinjaBearMonkey Je le connais, mais celui-ci est plus détaillé et souligné sur l'analyse de date
Optimizer
Je sais, je ne le considérerais certainement pas comme un doublon, mais je pensais simplement le mentionner.
NinjaBearMonkey
Les espaces de fin sur les dernières lignes du Taureau et des Poissons sont-ils intentionnels?
Siguza
@Siguza, vous pouvez de toute façon avoir jusqu'à 4 espaces de fin. Donc ça n'a pas d'importance :)
Optimizer

Réponses:

7

CJam, 296 284 272 265 264 octets

"03½åÙªWË#å¥ÜZ2ò'ýðDc}¦Ð£RÞ5ä<Üå§ÖÞYÏuäOe¤¶è2²|ZëßB«ô¬cm"257b2bSf*Qa/"®=&ðS¢Òpût£Ð`ç«^º,[öÄ©3¸YÝæ[%$>\D£(´õÓÆeUØRHáÄ¡ããîùK½ÊÆÇ:UBÍm¥·fèäBÓEwWOkQq×tÌVfè£g8·¨    q©ñäp-ÁgUÚ´Éõ'>r    Ê#"256bDb"
.\"'()-/:\_|J"f=.+sSN+/l~\K>+=

Essayez-le en ligne dans l' interpréteur CJam .

Idée

Nous commençons par joindre les douze signes en utilisant la chaîne <SP><LF>comme séparateur. Nous optons pour que les signes du zodiaque ne contiennent pas d'espaces de fuite, ce qui permet de les séparer facilement.

La chaîne jointe est longue de 542 octets. 236 de ces octets sont des espaces, ce qui représente presque la moitié d'entre eux. Nous construisons un tableau qui contient un 1 pour chaque espace et un 0 pour chaque non-espace. De cette façon, l'encodage d'un espace ne coûtera que 1 bit.

En supprimant tous les espaces de la chaîne jointe, nous nous retrouvons avec les caractères <LF>."'()-/:J\_|. Attribuer à chacun d'eux une valeur (par exemple, l'index dans cette chaîne) entre 0 et 12

Enfin, nous décodons les tableaux de base 2 et de base 13 ci-dessus en tant que tableaux d'octets.

Dans le programme final, pour une entrée donnée DD MM, nous calculons (int(MM) + (int(DD) > 20)) % 12, inversons le processus ci-dessus pour obtenir le tableau de tous les signes du zodiaque et sélectionnez celui qui convient.

Code

"03½åÙªWË#å¥ÜZ2ò'ýðDc}¦Ð£RÞ5ä<Üå§ÖÞYÏuäOe¤¶è2²|ZëßB«ô¬cm"

        e# Push the encoded space positions.

257b2b  e# Convert from base 257 to base 2.
Sf*     e# Replace 1's with spaces and 0's with empty strings.
Qa/     e# Split at empty strings.

"®=&ðS¢Òpût£Ð`ç«^º,[öÄ©3¸YÝæ[%$>\D£(´õÓÆeUØRHáÄ¡ããîùK½ÊÆÇ:UBÍm¥·fèäBÓEwWOkQq×tÌVfè£g8·¨ q©ñäp-ÁgUÚ´Éõ'>r    Ê#"

        e# Push the encoded non-space characters.

256bDb  e# Convert from base 256 to base 13.

"
.\"'()-/:\_|J"f=

        e# Replace each digit in base 13 by the corresponding character.

.+s     e# Interleave both arrays to create a string.
SN+/    e# Split at trailing spaces.
l~      e# Evaluate the input from STDIN.
\K>+    e# Add 1 to the month if the day is larger than 20.
=       e# Retrieve the corresponding element from the array.
Dennis
la source
Ð £ RÞ? DERP. . .
unclemeat
La plus longue solution de golf Lang que j'ai jamais vue.
Pavel
3

CJam, 324 octets

"%[hÿìs5!zaÆT=ªñ=Û]ÌUMàûÓ»¦f¼³ëµ1þÈUÑyéC4¬u1T9KÍü!+Úøöà&J~âZ®uRtkRÿ+*ÐFeÜPý¤SÙËU7óÎ?LXÝ2D@0¶ÆÀ¡kÚça­çªñܧ#iµ3L®ó&Ë'iºyè½?JS÷SjS`ösÓò»zjRoaÃIYrµ&M>ÍKaaúcg®Ð\p¨²:LqÜݶo¯ÆkµúÒ4Ezú©æ¼xP»¸¯gd^ßg±>ï ÃºDÎŧ@3Bßt\<GÒcû)ËûwíUÑdØoiTv>¤&ý°mÊ13ÛUÿØjª¬Ì±(¦¿çÍX4tõãÜÑ*ÃmÜ9ãSÁ3IþÜìÙ,"{_'~>33*32+-}%191bEb428Et"
 \"'()-./:\_a|J"f='a/q~\K>+=

Ma première tentative. Essayez-le en ligne

aditsu quitte parce que SE est MAL
la source
2

Python 2, 961 698 692 687 octets

Certainement aller encore plus loin au golf, je voulais juste poser une idée. Maintenant, en utilisant un dictionnaire.

a,b=raw_input().split()
b=int(b)
c='.-"-._.-"-._.-'
print{0:c+'\n'+c,1:"'-.    .-'\n   :  :\n --:--:--\n   :  :\n.-'    '-.",2:" .-.   .-.\n(_  \ /  _)\n     |\n     |",3:" .     .\n '.___.'\n .'   '.\n:       :\n:       :\n '.___.'",4:"._____.\n  | |\n  | |\n _|_|_\n'     '",5:"   .--.\n  /   _'.\n (_) ( )\n'.    /\n  '--'",6:"  .--.\n (    )\n(_)  /\n    (_.",7:" _\n' ':--.--.\n   |  |  |_\n   |  |  | )\n   |  |  |/\n        (J",8:"     __\n___.'  '.___\n"+'_'*12,9:" _\n' ':--.--.\n   |  |  |\n   |  |  |\n   |  |  |  ...\n         '---':",10:"      ...\n      .':\n    .'\n'..'\n.''.",11:"        _\n\      /_)\n \    /'.\n  \  /   :\n   \/ __.'"}[[[b-2,11][b<2],b-1][int(a)>20]]

Ancienne méthode, utilisant l'entrelacement.

d,m=raw_input().split()
m=int(m)
print'.\'  .       --.._  _ _  ".- _ .\n \n  - . _.-\' \'  .   _--     _   _-.\'_\'  .   ..\n:_:. -...\n\n -\n-. "--\n  (-_-._-\'.    ._.\n\n.\n\n\'|/ -_- \\_ (.   -.-  . __|  .\'.  -  _\n )\n \n  \n: _ _\n     . \\. \'( \'   -  \'|._ . . ":/\n \n)|_|\'/-\n  |   _ :_.  .\n(  _ \n)_-_\' _/|\n| \n.-) _)\n _   -:\n |   _  \\"-  _( |_|  -- \'|  __\n. .: ._) \n_ \' _- \n\n\n( _ \n .- :\'\'_ _ \'/-\n|  .. _|.\'  \n    |_ ..        _ \'\n        _|\n  :     |_ .     \'/    \'\\     \n   |\'  :|:   | \n.  \n \n       / . : \' )     -   - \n     \'   -   |       \'     :           \n       | |               \'           - :   | | \\ . \n       /               \'   | . _   .   / . _   _   \n . .   _     \n \'   _           .           \'                                                               (           J             \'           -           -           -           \'           :  '[[m-2,m-1][int(d)>21]::12].rstrip()
Kade
la source
2

Python 2, 565 568 553 octets

def z(d,m):b="\n "+"  |"*3;c=" _\n' ':--.--.";a="  ...\n      ";print["\      /_)\n \    /'.\n  \  /   :\n   \/ __.'",'.-"-._.-"-._.-\n'*2,"'-.    .-'\n   :  :\n --:--:--\n   :  :\n.-'    '-.",' .-.   .-.\n(_  \ /  _)'+'\n     |'*2," .     .\n '.___.'\n .'   '.\n:       :\n:       :\n '.___.'","._____.\n  | |\n  | |\n _|_|_\n'     '","   .--.\n  /   _'.\n (_) ( )\n'.    /\n  '--'",'  .--.\n (    )\n(_)  /\n    (_.',c+b+"_"+b+" )"+b+"/\n        (J","     __\n___.'  '.___\n"+"_"*12,c+b*3+a+"   '---':","    "+a+".':\n    .'\n'..'\n.''."][m%12-(d<21)]

J'étais donc un peu paresseux et j'ai décidé de ne pas jouer au golf avec cet AAotD. Au lieu de cela, j'ai décidé de laisser le golf python lui-même.

La solution ci-dessus a été créée à l'aide du code ci-dessous:

full_string = """
\      /_)
 \    /'.
  \  /   :
   \/ __.'
*
.-"-._.-"-._.-
.-"-._.-"-._.-
*
...               # The others in this list as well
*
      ...
      .':
    .'
'..'
.''.
"""

# Golf the input string
string_list = full_string.split('*')
# Remove begin and end \n
string_list = [s[1:-1] for s in string_list]
# Remove unnescessary repr characters
golf = repr(string_list).replace(r'\\ ', r'\ ').replace(r'\\/', r'\/').replace(', ', ',')
# Special case for the Aquarius as it's a full duplicate
middle = golf.find('\\n', 50)
end = golf.find(',', middle)
golf = golf[0:middle+2] + "'*2" + golf[end:]
# Special case for the 12 underscores
golf = golf.replace('____________"', '"+"_"*12')
# Replace the three bars and their whitespace
golf = golf.replace('\\n   |  |  |', '"+b+"')
# Replace the bar-cover
cover = '" _\\n\' \':--.--."'
golf = golf.replace(cover, 'c')
# Replaces aries' foot
golf = golf.replace("\\n     |\\n     |'", "'+'\\n     |'*2")
# Replace dots
golf = golf.replace('  ...\\n      ', '"+a+"')
# Remove empty strings and optimize b's
golf = golf.replace('""+', '').replace('b+b+b', 'b*3')

# Surround the lookup table with the function that that prints the correct zodiac sign for the day/month
golf = 'def z(d,m):a="  ...\\n      ";b="\\n "+"  |"*3;c=" _\\n\' \':--.--.";print' + golf + '[m%12-(d<21)]'
Matty
la source
Cela ne produit pas du tout la bonne sortie. Tous doivent être décalés, et si vous dépassez 20,12, l'index de la liste est hors de portée. z (21,1) devrait produire le Verseau, mais il produit des photos, etc.
Kade
@ Vioz- Wow, je deviens bâclé. Merci, cela fonctionne correctement maintenant.
Matty
1

Perl, 414

Pas grand chose à faire ici, juste une compression de dictionnaire appliquée:

#!perl -p
/ /;$i=$'%12-($`<21);
$_="cc_
\\ct_s \\c/'ga\\thlh\\/ __ijkee
keej'-.ck'n q:q:qnk'c'-gA k.hkg(_a\\ /a_sm|
m|j .mg oi
 ih'g:chl:chl oij.d__grr _|_|_
'm'jhk-gth_'g (_) ( s'.c/
a'q'jak-g (cs(_)t
c(_.f_b )b/
cc(Jjm__
diao
ddddfbbpm'q-':jcpailci
'.i
i'g";
1while s![a-t]!(split z,"  z
a |a|a|zaaz___z\"-._.-z
A _
' ':--.--.bz.
za z.'z
Az.-z:
zc z
h:alz'.dza..gcz--za| |
z)
za/")[(ord$&)%97]!e;$_=(split A)[$i]

Testez- moi .

nutki
la source