Étendre le soleil ASCII

43

Ecrivez un programme qui prend (via STDIN / ligne de commande) un entier non négatif N.

Lorsque N est Oégal à 0, votre programme doit être imprimé (c'est la capitale, Oh, pas zéro).

Lorsque N vaut 1, votre programme devrait imprimer

\|/
-O-
/|\

Quand N vaut 2, votre programme devrait imprimer

\ | /
 \|/
--O--
 /|\
/ | \

Quand N vaut 3, votre programme devrait imprimer

\  |  /
 \ | /
  \|/
---O---
  /|\
 / | \
/  |  \

Pour un plus grand N, ce motif continue exactement de la même manière. Chacun des huit rayons du « soleil » doit être faite de N des appropriés -, |, /ou \caractères.

Détails

  • Au lieu d'un programme, vous pouvez écrire une fonction qui prend un entier. La fonction doit imprimer le dessin du soleil normalement ou le renvoyer sous forme de chaîne.
  • Vous devez soit

    • ne pas avoir d'espaces de fin, ou
    • n’avez que suffisamment d’espaces de fin pour que le motif soit un rectangle parfait (2N + 1) * (2N + 1).
  • La sortie de tout ou partie des N peut éventuellement avoir une nouvelle ligne.

Notation

Le code le plus court en octets gagne.

Les passe-temps de Calvin
la source
Une nouvelle ligne principale est-elle autorisée? Particulièrement intéressant pour N=0.
Jakube
@ Jakube Non. Trailing uniquement.
Les passe-temps de Calvin

Réponses:

12

Pyth, 39 38 36 octets

jbXmXXj\|m*\ Q2d\\_hd\/JhyQQX*\-JQ\O

Essayez-le en ligne: Compilateur / Exécuteur Pyth

Explication

jbXmXXj\|m*\ Q2d\\_hd\/JhyQQX*\-JQ\O   implicit: Q = input
                       JhyQ            J = 1 + 2*Q
    m                  J               map each d of [0,1,...,2*Q] to:
          *\ Q                           " "*input
         m    2                          list with twice " "*input
      j\|                                join this list by "|"
     X         d\\                       replace the value at d to "\"
    X             _hd\/                  replace the value at -(d+1) to "/"
  X                        Q           replace line Q by:
                             *\-J        "-"*J
                            X    Q\O     replace element at Q with "O"
jb                                     join by "newlines"

Une autre solution de 36 octets serait:

jbmXXj\|m*?\-KqdQ\ Q2d\\_hd?\OK\/hyQ
Jakube
la source
26

C: 116 102 99 95 92 90

s(n){for(int c=-n,r=c;r<=n;c++)putchar(c>n?c=-c,r++,10:c?r?c-r?c+r?32:47:92:45:r?124:79);}

Je pense que je me rapproche assez d'une solution minimale en utilisant cette approche, mais je ne peux m'empêcher de penser qu'il existe une bien meilleure approche dans C. Ungolfed:

void s(int n) {
  for(
    int c = -n, r = c;
    r <= n;
    c++
  )
    putchar(
      c > n
        ? c = -c, r++, '\n'
        : c
          ? r
            ? c - r
              ? c + r
                ? ' '
                : '/'
              : '\\'
            : '-'
          : r
            ? '|'
            : 'O'
    );
}
Fors
la source
7
"c ++" en C ... heh!
bjb568
Je suis content que tu l'aies pas golfé. Ces si ternaires sont fous!
ldam
Vous pouvez économiser 2 octets supplémentaires et le rendre conforme à la vc 2012;)c,r;s(n){for(r=c=-n;r<=n;c++)putchar(c>n?c=-c,r++,10:c?r?c-r?c+r?32:47:92:45:r?124:79);}
Johan du Toit
21

GNU sed, 252 + 1

Ouf - j'ai battu la réponse php!

Score + 1 pour utiliser le -rparamètre.

En raison des limitations de sed, nous devons graver près de 100 octets, il suffit de convertir N en chaîne de N espaces. Le reste est le truc amusant.

/^0/{y/0/O/;q}
s/./<&/g
s/9/8 /g
s/8/7 /g
s/7/6 /g
s/6/5 /g
s/5/4 /g
s/4/3 /g
s/3/2 /g
s/2/1 /g
s/1/ /g
s/0//g
:t
s/ </<          /g
tt
s/<//g
:
s/ //
s^.*^\\&|&/^;ta
:a
/\\$/q
p
s^\\\|/^-O-^;tn
s^(\\)? (/)?^\2 \1^g;ta
:n
y/ /-/
p
s^-O-^/|\\^
y/-/ /
ta

Explication

  • La première ligne est une sortie anticipée pour le cas N = 0.
  • Les 15 lignes suivantes (jusqu’à la :) convertissent N en une chaîne de N espaces
  • s/ // supprime un espace
  • s^.*^\\&|&/^;taconvertit les espaces N-1 en: \+ N-1 espaces + |+ N-1 espaces +/
  • Itérez, imprimez chaque itération et déplacez \un espace à droite et /un espace à gauche ...
  • ... jusqu'à ce que nous correspondions \|/, qui est remplacé par -O-et saute à l' nétiquette
  • remplacer par -et imprimer
  • remplacer -0-par /|\, et remplacer par -et sauter dans la boucle principale
  • Itérez, imprimez chaque itération et déplacez \un espace à droite et /un espace à gauche ...
  • ... jusqu'à ce que nous correspondions \$qui indique étaient terminés, et quittez.

Sortie

 $ for i in {0..3}; do sed -rf asciisun.sed <<< $i ; done
 O
 \|/
 -O-
 /|\
 \ | /
  \|/ 
 --O--
  /|\ 
 / | \
 \  |  /
  \ | / 
   \|/  
 ---O---
   /|\  
  / | \ 
 /  |  \
 $
Trauma numérique
la source
16

J, 37 34 40 octets

1:echo('O\/-|'{.@#~0=+&|,-,+,[,])"*/~@i:

Usage:

   (1:echo('O\/-|'{.@#~0=+&|,-,+,[,])"*/~@i:) 2  NB. prints to stdout:
\ | /
 \|/ 
--O--
 /|\ 
/ | \

Explication (de gauche à droite):

  • i: génère la liste -n, -(n-1), ..., n-1, n
  • ( )"*/~@i:crée le produit Descartes de i: avec lui-même dans un arrangement matriciel, par exemple pour n = 1crée la 3-by-3matrice suivante

    ┌─────┬────┬────┐
    │-1 -1│-1 0│-1 1│
    ├─────┼────┼────┤
    │0 -1 │0 0 │0 1 │
    ├─────┼────┼────┤
    │1 -1 │1 0 │1 1 │
    └─────┴────┴────┘
    
  • pour chaque élément de matrice avec des entiers x ynous faisons ce qui suit

  • +&|,-,+,[,] calculer une liste de propriétés

    • +&| abs(x)+abs(y), est égal à 0ssi (si et seulement si) x=0ety=0
    • -xy, égal à 0ssf x=yon est sur la diagonale
    • +x + y, égal à 0ssi x=-yon est sur l'anti-diagonale
    • [x, égal à 0ssf x=0on est sur la rangée du milieu
    • ]y, est égal à 0Ssf y=0nous sommes dans la colonne du milieu
  • 'O\/-|'#~0=Comparez ces valeurs de propriété ci-dessus à 0et prenez le icaractère th de la chaîne 'O\/-|'si la ipropriété th est true.

  • le premier caractère de la chaîne résultante sera toujours celui dont nous avons besoin, si la chaîne est vide, nous avons besoin d'un espace
  • {. prend le premier caractère d'une chaîne et s'il n'y en a aucun, il retourne un caractère d'espace comme remplissage, comme nous en avons besoin
  • nous avons maintenant la matrice exacte dont nous avons besoin, donc nous l’imprimons sur stdout une fois avec 1:echo

Essayez-le en ligne ici.

randomra
la source
5
Ceci est la version non-golfée?! Je me sens parfois comme un programmeur assez moyen, puis pour une raison quelconque je me retrouve sur codegolf et je vois ce que vous faites et vous ne pouvez pas vous empêcher de vous sentir idiot.
JustSid
@JustSid Eh bien, le texte n'était pas à jour avec le code, mais techniquement, je n'ai jamais écrit que le code est non-golfé. :)
randomra
C'est
quand
2
@JustSid Ce n'est pas moins impressionnant, mais le code J ressemble à cela, et cela semble être un défi pour lequel ce serait un bon langage. C'est une réponse très impressionnante, mais tout le reste aussi dans J :)
undergroundmonorail
11

PHP, 182 octets

Cela semblait être une activité amusante pour ma première réponse. Les commentaires sur mon code sont les bienvenus.

<?php function s($n){$e=2*$n+1;for($i=0;$i<$e*$e;$i++){$x=$i%$e;$y=floor($i/$e);echo$y==$x?($x==$n?"O":"\\"):($e-1==$x+$y?"/":($y==$n?"-":($x==$n?"|":" ")));echo$x==$e-1?"\n":"";}}?>

Voici le code non-golfé avec des commentaires:

<?php
function s($n) {
    $e=2*$n+1; //edge length
    for($i=0;$i<$e*$e;$i++) {
        $x = $i%$e; // current x coordinate
        $y = floor($i/$e); // current y coordinate

        if ($y==$n&&$x==$n) {
            // center of square
            echo'O';
        }
        else if ($y==$n) {
            // horizontal line
            echo'-';
        }
        else if ($x==$n) {
            // vertical line
            echo'|';
        }
        else if ($y==$x) {
            // diagonal line from top-left to bottom right
            echo'\\';
        }
        else if (($y-$n)==($n-$x)) {
            // diagonal line from bottom-left to top-right
            echo'/';
        }
        else {
            // empty space
            echo' ';
        }
        if ($x==$e-1) {
            // add new line for the end of the row
            echo"\n";
        }
    }
}?>
<pre>
<?php s(10); ?>
</pre>

Édité avec code par royhowie

Kodos Johnson
la source
3
Salut :-) Bon premier effort. Vous pouvez cependant réduire votre code à plusieurs endroits. Par exemple, if(($y-$h)==($x-$h))fait la même chose que if(($y==$x). Vous pouvez enregistrer un autre personnage en le remplaçant if($x==y$)foo();else bar();par if($x^$y)bar();else foo();. Vous devriez également essayer d'utiliser des opérateurs ternaires au lieu d' if .. elseinstructions.
ossifrage délirant
Les opérateurs ternaires sont un bon conseil
Nick
174 octets:function s($n){$e=2*$n+1;for($i=0;$i<$e*$e;$i++){$x=$i%$e;$y=floor($i/$e);echo$y==$x?($x==$n?"O":"\\"):($e-1==$x+$y?"/":($y==$n?"-":($x==$n?"|":" ")));echo$x==$e-1?"\n":"";}}
royhowie
1. il n'y a pas besoin de $r; Il suffit d'utiliser echo( $r.=est la même quantité d'octets que echo). 2. opérateur ternaire utilisé (enregistre beaucoup de caractères). 3. $hétait inutile puisqu'il égalait $n. 4. Vous n'avez pas besoin d'utiliser floorfor $x = floor($i%$e);, puisqu'un module sur un entier n'aura pas besoin d'être arrondi.
royhowie
@squeamishossifrage je n'y avais jamais pensé. Merci pour les conseils!
Kodos Johnson
9

Python 2, 99

n=input()
R=range(-n,n+1)
for i in R:print''.join("O\|/ -"[[R,i,0,-i,j].index(j)^(i==0)]for j in R)

Prints ligne par ligne, créant chaque ligne en vérifiant si la coordonnée (i,j)(centrée sur (0,0)) satisfait j==-i, j==0, j==i, ou pas, avec un hack pour faire le travail de la ligne centrale.

Xnor
la source
Je pense que vous pouvez utiliser Rau lieu de .5sauvegarder 1 octet.
randomra
@randomra C'est intelligent, merci. Jusqu'à deux chiffres!
xnor
8

CJam, 48 45 43 41 38 octets

C'est encore trop long et je continue à faire des choses redondantes, mais voici:

ri:R{_S*"\|/"@R-~S**1$N}%'-R*'O1$W$sW%

Essayez-le en ligne ici

Optimiseur
la source
7

SpecBAS - 117 octets

1 INPUT s: LET t=s*2: FOR y=0 TO t: PRINT AT y,y;"\";AT y,t/2;"|";AT t-y,y;"/";AT t/2,y;"-": NEXT y: PRINT AT s,s;"O"

Ceci imprime les barres obliques et les tirets dans une boucle, puis pointe le "O" au milieu.

Sortie utilisant 1, 2 et 9

entrez la description de l'image ici

Brian
la source
Un utilisateur anonyme a suggéré au changement "-": NEXT y: PRINT AT s,s;"O"de "-";AT s,s;"O": NEXT ysauver deux octets.
Martin Ender
7

JavaScript (ES6) 97 98

Cela semble assez différent ...

// GOLFED
f=n=>(y=>{for(t='';++y<n;t+='\n')for(x=-n;++x<n;)t+='-O /\\|'[y?x?x-y?x+y?2:3:4:5:+!x]})(-++n)||t

// Ungolfed

F=n=>{
  ++n;
  t = '';
  for (y = -n; ++y < n; t += '\n')
    for (x = -n; ++x < n; )
      if (y != 0)
        if (x != 0)
          if (x != y)
            if (x != -y)
              t += ' '
            else
              t += '/'
          else
            t += '\\'
        else
          t += '|'
      else
        if (x != 0)
          t += '-'
        else 
          t += 'O'
  return t;
}
    
// TEST
function test(){ OUT.innerHTML = f(N.value|0); }
test()
input { width: 4em }
N: <input id=N value=5><button onclick="test()">Go</button>
<pre id="OUT"></pre>

edc65
la source
Beau. J'aurais dû penser à une fermeture pour utiliser normal pour les boucles.
nderscore
J'aime celui la. J'avais essayé d'en écrire une en utilisant une chaîne de caractères et en accédant à un index spécifique, mais le vôtre est beaucoup plus court.
royhowie
6

OS / 2 Classic Rexx, 102 ... ou 14 pour la "version du tricheur"

Sortez les sauts de ligne pour "jouer au golf".

w='%1'
o=center('O',w,'-')
m='center(space("\|/",w),%1)'
do w
  w=w-1
  interpret "o="m"|o|"m
end l
say o

Version du tricheur, nommez le script, quel que soit le code source de votre choix, sous 255 caractères (nécessite un disque HPFS):

interpret '%0'

EDIT: Juste pour être clair, la version du tricheur n'est pas censée compter! C'est juste pour être stupide et montrer qu'un vieux chien peut encore faire des tours. :)

Par exemple, pour le divertissement et les jeux, implémentation des expressions "lambda" de style Java-8 / C11 sur un itérateur de liste. Non testé, mais devrait fonctionner sur un ordinateur central IBM d'environ 1979. ;)

ForEachInList( 'Months.January.Days', 'Day' -> 'SAY "You have an appointment with" Day.Appointment.Name "on" Day.Appointment.Date' )
EXIT

ForEachInList: 
    SIGNAL ON SYNTAX
    PARSE ARG MyList "," MyVar "->" MyCommand
    INTERPRET ' MyListCount = ' || MyList || '.Count'
    DO ListIndex = 1 TO MyListCount
       INTERPRET MyVar || ' = ' || MyList || '.' || ListIndex
       INTERPRET MyCommand
    END
    RETURN
SYNTAX:
    SAY MyCommand ' is not a valid expression. '
    EXIT

- Le code d'appel suppose que vous avez déjà créé une tige (tableau), naturellement.

Lisa
la source
Pour votre version de tricheur: si le nom du fichier d'un programme n'est pas arbitraire, il doit être inclus dans le nombre d'octets .
Martin Ender
C'est suffisant. La version de Cheater n'était pas du tout sérieuse! :) ... c'est pourquoi j'ai posté la "vraie" réponse à 102. C'était juste pour l'amour de la nouveauté.
Lisa
@lisa sauf que ce n'est pas nouveau du tout;). En outre, cela briserait le script de classement s'il était utilisé dans ce défi.
Optimiseur
6

Haskell, 109 98 96 octets

Merci à nimi et mauris pour leur aide!

0#0='O'
0#_='-'
_#0='|'
i#j|i==j='\\'|i== -j='/'|1<2=' '
f n=unlines[map(i#)[-n..n]|i<-[-n..n]]

Explication:

L'opérateur #spécifie quel caractère apparaît aux coordonnées (i, j), avec le soleil centré à (0,0). Function fconstruit la chaîne de résultat en mappant #toutes les paires de coordonnées allant de -n à n.

Usage:

ghci> putStr $ f 2
\ | /
 \|/ 
--O--
 /|\ 
/ | \
utilisateur40671
la source
Vous pouvez enregistrer quelques octets en utilisant un opérateur infixe au lieu de s, par exemple 0#0='O', 0#_='-', etc. , et au 1<2lieu de True.
nimi
Peut-être map(i#)[-n..n]économiser deux octets.
Lynn
4

R, 177 149 octets

Mickey T. est l'homme! Il m'a aidé à réparer ma solution initialement incorrecte et à économiser 28 octets. Merci Mickey!

m=matrix(" ",(w=2*(n=scan()+1)-1),w);m[row(m)==rev(col(m))]="/";diag(m)="\\";m[,n]="|";m[n,]="-";m[n,n]="O";m[,w]=paste0(m[,w],"\n");cat(t(m),sep="")

Ungolfed + explication:

# Create a matrix of spaces, read n from stdin, assign w=2n+1
m <- matrix(" ", (w <- 2*(n <- scan() + 1) - 1), w)

# Replace the opposite diagonal with forward slashes
m[row(m) == rev(col(m))] <- "/"

# Replace the diagonal with backslashes
diag(m) <- "\\"

# Replace the vertical center line with pipes
m[, n] <- "|"

# Replace the horizontal center line with dashes
m[n, ] <- "-"

# Put an O in the middle
m[n, n] <- "O"

# Collapse the columns into single strings
m[, w] <- paste0(m[, w], "\n")

# Print the transposed matrix
cat(t(m), sep = "")

Toute autre suggestion est la bienvenue!

Alex A.
la source
1
Désolé Alex, tu as raté les rayons verticaux. Quelques modifications pourraient être apportées afin de raccourcir le processus sans modifier le processus général. Le scann'a pas vraiment besoin du w=. Il peut également être déplacé plus profondément dans les commandes. Le ifpeut être abandonné si vous modifiez la façon dont la matrice est traitée dans quelques cas. En les appliquant, je reçois m=matrix(" ",(w=2*(n=scan()+1)-1),w);m[row(m)-rev(col(m))==0]='/';diag(m)="\\";m[,n]='|';m[n,]="-";m[n,n]="O";m[,w]=paste0(m[,w],'\n');cat(t(m),sep=''). Plus de golf possible, je pense.
MickyT
@MickyT: C'est fantastique. Merci beaucoup d'avoir remarqué mon erreur et d'avoir prouvé une bien meilleure solution! J'ai édité la réponse.
Alex A.
4

C #, 230 226 octets

string g(int n){string r="";int s=n*2+1;for(int h=0;h<s;h++){for(int w=0;w<s;w++){if(h==w){if(w==n){r+="O";}else{r+="\\";}}else if(w==s-h-1){r+="/";}else if(w==n){r+="|";}else if(h==n){r+="-";}else{r+=" ";}}r+="\n";}return r;}

Comme demandé, la version non-golfée: string ug (int n) {

        // The sting we'll be returning
        string ret = ""; 

        // The width and height of the output
        int s = n * 2 + 1; 

        // for loop for width and height
        for (int height = 0; height < s; height++) 
        {
            for (int width = 0; width < s; width++) 
            {
                // Matches on top-left to bottom-right diagonal line
                if (height == width) 
                {
                    // If this is the center, write the 'sun'
                    if (width == n) 
                    {
                        ret += "O"; 
                    }
                    // If this is not the center, add the diagonal line character
                    else 
                    {
                        ret += "\\"; 
                    }
                }
                // Matches on top-right to bottom-left diagonal line
                else if (width == s - height - 1) 
                { 
                    ret += "/";
                }
                // Matches to add the center line
                else if (width == n) 
                { 
                    ret += "|";
                }
                // Matches to add the horizontal line
                else if (height == n) 
                { 
                    ret += "-";
                }
                // Matches all others
                else 
                { 
                    ret += " "; 
                } 
            } 
            // Add a newline to separate each line
            ret += "\n"; 
        } 
        return ret; 
    }

Ceci est mon premier post, donc excuses si j'ai fait quelque chose de mal. Tous les commentaires et corrections sont les bienvenus.

Transmission
la source
Aussi, s=2*n+1plutôt que s=(n*2)+1et w==s-h-1plutôt que de w==(s-h)-1le rendre un peu plus court.
Alex A.
nice, peut voler votre méthode de construction de chaîne. ça m'énerve que linq soit plus long que pour les boucles :(
Ewan
J'ai ajouté la version ungolfed :)
Transmission
4

Ruby: 98 92 caractères

Proc qui retourne une chaîne avec le soleil.

f=->n{x=(0..m=n*2).map{|i|s=?|.center m+1
s[i]=?\\
s[m-i]=?/
s}
x[n]=?O.center m+1,?-
x*?\n}

Échantillon échantillon:

irb(main):001:0> f=->n{x=(0..m=n*2).map{|i|s=?|.center m+1;s[i]=?\\;s[m-i]=?/;s};x[n]=?O.center m+1,?-;x*?\n}
=> #<Proc:0x000000020dea60@(irb):1 (lambda)>
irb(main):002:0> (0..3).each {|i| puts f[i]}
O
\|/
-O-
/|\
\ | /
 \|/ 
--O--
 /|\ 
/ | \
\  |  /
 \ | / 
  \|/  
---O---
  /|\  
 / | \ 
/  |  \
=> 0..3
homme au travail
la source
4

Rouille, 215 caractères

fn a(n:usize){for i in 0..n{println!("{}\\{}|{1}/{0}",s(i),s(n-i-1))}println!("{}O{0}",vec!["-";n].concat());for i in(0..n).rev(){println!("{}/{}|{1}\\{0}",s(i),s(n-i-1))}}fn s(n:usize)->String{vec![" ";n].concat()}

J'ai essayé d'utiliser une méthode de découpage en chaîne (en créant une chaîne d' n-1espaces et en effectuant un découpage vers et à partir d'un index) comme ceci:

fn a(n:usize){let s=vec![" ";n-(n>0)as usize].concat();for i in 0..n{println!("{}\\{}|{1}/{0}",&s[..i],&s[i..])}println!("{}O{0}",vec!["-";n].concat());for i in(0..n).rev(){println!("{}/{}|{1}\\{0}",&s[..i],&s[i..])}}

Mais c'est en fait 3 caractères plus long.

Code non golfé:

fn asciisun_ungolfed(n: usize) {
    for i in 0..n {
        println!("{0}\\{1}|{1}/{0}", spaces(i), spaces(n-i-1))
    }
    println!("{0}O{0}", vec!["-"; n].concat());
    for i in (0..n).rev() {
        println!("{0}/{1}|{1}\\{0}", spaces(i), spaces(n-i-1))
    }
}
fn spaces(n: usize) -> String { vec![" "; n].concat() }

Ce que j’aime, c’est la façon dont je rase quelques caractères sur les chaînes de formatage. Par exemple,

f{0}o{1}o{1}b{0}ar

est équivalent à

f{}o{}o{1}b{0}ar

parce que "l'incrémentation automatique" de la position de l'argument de chaîne de format n'est pas affectée par la spécification manuelle du nombre et agit de manière totalement indépendante.

Poignée de porte
la source
4

Octave 85

Bulding matrices comme toujours =) eyeproduit une matrice d'identité, le reste est explicite, je pense.

m=(e=eye(2*(k=input('')+1)-1))*92+rot90(e)*47;m(:,k)='|';m(k,:)=45;m(k,k)='o';[m,'']
flawr
la source
Encore deux octets meilleurs que le mien :( j'ai en fait essayé quelque chose de semblable à cela au départ, mais je n’ai pas pu le prendre suffisamment petit - je ne savais pas que je pouvais faire "m (:, k) = '|'". Belle soumission!
Oebele
4

IDL 8.3, 135 octets

Je ne sais pas si cela peut être joué au golf plus ... C'est très simple. Tout d'abord, nous créons un m x mtableau ( m=2n+1) de chaînes vides; puis, nous dessinons les personnages dans les lignes ( y=x, y=-x, y=net x=n). Ensuite, nous lâchons O en un point (n, n)et imprimons le tout, sous la forme de mchaînes de longueur 1 sur chaque ligne, de manière à éviter tout espacement supplémentaire par rapport à l’impression native du tableau.

pro s,n
m=2*n+1
v=strarr(m,m)
x=[0:m-1]
v[x,x]='\'
v[x,m-x-1]='/'
v[n,x]='|'
v[x,n]='-'
v[n,n]='O'
print,v,f='('+strtrim(m,2)+'A1)'
end

Tester:

IDL> s,4
\   |   /
 \  |  / 
  \ | /  
   \|/   
----O----
   /|\   
  / | \  
 /  |  \ 
/   |   \
sirpercival
la source
"Au lieu d'un programme, vous pouvez écrire une fonction qui prend un entier. La fonction devrait imprimer le design du soleil normalement ou le renvoyer sous forme de chaîne."
sirpercival
hahaha pas de soucis :)
sirpercival
3

Matlab, 93 87 octets

Malheureusement, l'entête de la fonction doit être si grosse ... A part ça, je pense que c'est assez bien joué au golf. Je me demande si cela pourrait être mieux fait avec certaines des différences de syntaxe dans Octave.

N=input('');E=eye(N)*92;D=rot90(E)*.52;H=ones(1,N)*45;V=H'*2.76;[E V D;H 79 H;D V E '']
Oebele
la source
Vous pouvez simplement créer un programme avec N=input('')pour enregistrer 2 caractères. En dehors de cela, vous pouvez simplement écrire [E V D;H 79 H;D V E '']pour convertir toute la matrice en tableau de caractères, ce qui vous permettra d'économiser un ou plusieurs octets supplémentaires. (Je viens de soumettre un programme Octave avec une approche légèrement différente, mais avant de trouver le vôtre =)
flawr
J'avais d'abord la ligne d'entrée, mais pour une raison quelconque, j'ai pensé à tort que ce n'était pas permis ... Merci pour l'autre astuce cependant!
Oebele
3

Javascript ( ES7 Draft ) 115

f=l=>[['O |/\\-'[y^x?z+~x^y?y^l?x^l?1:2:5:3:x^l&&4]for(x in _)].join('')for(y in _=[...Array(z=2*l+1)])].join('\n')


// Snippet demo: (Firefox only)
for(var X of [0,1,2,3,4,5])
    document.write('<pre>' + f(X) + '</pre><br />');

Nderscore
la source
2

Pyth - 52 octets

La partie difficile était de savoir comment changer les barres obliques de chaque côté. Je me suis décidé pour définir un lambda qui utilise les symboles à utiliser.

KdMms[*Kt-QdG*Kd\|*KdH)_UQjbg\\\/p\O*Q\-*\-Qjb_g\/\\

Peut probablement être joué au golf plus, explication à venir.

Essayez-le en ligne ici .

Maltysen
la source
2

Perl, 94

Il y a beaucoup d'opérateurs ternaires imbriqués ici, mais je pense que le code est assez simple.

$n=<>;for$x(-$n..$n){for$y(-$n..$n){print$x^$y?$x+$y?$x?$y?$":'|':'-':'/':$x?'\\':'O'}print$/}

Essayez-le ici: ideone.com/E8MC1d

ossifrage délirant
la source
1
88B: for$x(-($n=<>)..$n){map{print$x^$_?$x+$_?$x?$_?$":'|':'-':'/':$x?'\\':O}-$n..$n;print$/}- Quelques ajustements: convertir l’intérieur pour mapper et changer $ y en $ _; en ligne ($n=<>).
alexander-brett
2

C # - 291 (programme complet)

using System;using System.Linq;class P{static void Main(string[] a){Func<int,int,int,char>C=(s,x,i)=>x==(2*s+1)?'\n':i==s?x==s?'O':'-':x==s?'|':x==i?'\\':x==2*s-i?'/':' ';int S=int.Parse(a[0])*2;Console.Write(Enumerable.Range(0,(S+1)*(S+1)+S).Select(z=>C(S/2,z%(S+2),z/(S+2))).ToArray());}}
Ewan
la source
J'y travaille!!
Ewan
1

JavaScript (ES6), 139 135 140 + 1 octets

(+1 est pour -pdrapeau avec noeud dans la console)

fixé:

t=(n,m)=>(m=2*n+1,(A=Array).from(A(m),(d,i)=>A.from(A(m),(e,j)=>i==j?j==n?"O":"\\":m-1==j+i?"/":i==n?"-":j==n?"|":" ").join("")).join("\n"))

usage:

t(3)
/*
\  |  /
 \ | / 
  \|/  
---O---
  /|\  
 / | \ 
/  |  \
*/

ungolfed:

var makeSun = function (n, m) {
    m = 2 * n + 1;    // there are 2*n+1 in each row/column
    return Array.from(Array(m), function (d, i) {
        return Array.from(Array(m), function (e, j) {
            // if i is j, we want to return a \
            // unless we're at the middle element
            // in which case we return the sun ("O")
            if (i == j) {
                return j == n ? "O" : "\\";
            // the other diagonal is when m-1 is j+i
            // so return a forward slash, /
            } else if (m - 1 == j + i) {
                return "/";
            // the middle row is all dashes
            } else if (i == n) {
                return "-";
            // the middle column is all pipes
            } else if (j == n) {
                return "|";
            // everything else is a space
            } else {
                return " ";
            }
        }).join("");
    }).join("\n");
}
Royhowie
la source
2
Vous semblez manquer deux rayons.
Oh, zut, j'ai oublié de rajouter ça…
royhowie
(A=Array).from(A(m))
Shmiddty
@MichaelT je l'ai corrigé, mais je pense que je peux le
jouer un
@Shmiddty merci pour la suggestion! qui a sauvé beaucoup de personnages
royhowie
1

Python 3, 193 186 octets

Golfé

def f(n):
 s,b,e,d,g=' \\/|-';p,r,i='',int(n),0
 while r:print(s*i+b+s*(r-1)+d+s*(r-1)+e);r-=1;i+=1
 print(g*n+'O'+g*n);r+=1;i=n-1
 while r<n+1:print(s*i+e+s*(r-1)+d+s*(r-1)+b);r+=1;i-=1

Sortie

>>> f(3)
\  |  /
 \ | /
  \|/
---O---
  /|\
 / | \
/  |  \

>>> f(5)
\    |    /
 \   |   /
  \  |  /
   \ | /
    \|/
-----O-----
    /|\
   / | \
  /  |  \
 /   |   \
/    |    \

Ungolfed

def f(n):
    s, b, e, d, g = ' \\/|-'
    p, r, i = '', int(n), 0
    while r:
        print(s*i + b + s*(r-1) + d + s*(r-1) + e)
        r -= 1
        i += 1
    print(g*n + 'O' + g*n)
    r += 1
    i = n-1
    while r < n+1:
        print(s*i + e + s*(r-1) + d + s*(r-1) + b)
        r += 1
        i -= 1
Zach Gates
la source
1
Il y a quelques choses à jouer ici, mais le plus important est votre argument par défaut. s=' ',b='\\',f='/',d='|',g='-'est très long, alors vous feriez mieux de le déplacer en ajoutant s,b,f,d,g=" \/|-"à la deuxième ligne.
Sp3000
Je voulais dire " \/|-"comme une seule chaîne, plutôt que de la diviser en caractères individuels. Vous pouvez décompresser d'une chaîne comme x,y,z="123", ce qui en fait x="1", y="2"et z="3".
Sp3000
Edité à nouveau. Merci @ Sp3000
Zach Gates
1

CJam, 59 55 octets

ri:A,W%{_S*"\|/"\*\A\-(S*_@@++}%_Wf%W%['-A*_'O\++]\++N*

Cela ne gagnera aucun prix tel quel, mais j'étais assez content que cela fonctionne!

Merci à Sp3000 pour ses astuces de golf.

Claudiu
la source
1
Bon travail! Voici quelques conseils: 1) Vous pouvez utiliser Sla 'version au lieu de la version pour l'espace et 2) '-A*'O'-Avous pouvez le faire '-A*_'O\car la générer deux fois est long
Sp3000
1

Python, 175 129 127 125 octets

s,q,x=' ','',int(input())
for i in range(x):d=(x-i-1);q+=(s*i+'\\'+s*d+'|'+s*d+'/'+s*i+'\n')
print(q+'-'*x+'O'+'-'*x+q[::-1])

Essayez-le en ligne ici .

Tim
la source
1

Ruby - 130 octets

def f(n);a=(0...n).map{|i|' '*i+"\\"+' '*(n-1-i)+'|'+' '*(n-1-i)+'/'+' '*i};puts(a+['-'*n+'O'+'-'*n]+a.reverse.map(&:reverse));end

usage:

irb(main):002:0> f(3)
\  |  /
 \ | /
  \|/
---O---
  /|\
 / | \
/  |  \
Tomáš Dundáček
la source
1
Appliqué un vieux truc: f=->n{a=(0...n).map{|i|(s=' ')*i+?\\+s*(m=n-1-i)+?|+s*(m)+?/+s*i};puts(a+[?-*n+'O'+?-*n]+a.reverse.map(&:reverse))}(Voir Astuces pour jouer au golf en Ruby pour plus d’informations.)
manatwork
1

Perl 85 91 90 89 86B

map{$_=$r||O;s/^|$/ /mg;s/ (-*O-*) /-$1-/;$r="\\$s|$s/
$_
/$s|$s\\";$s.=$"}1..<>;say$r

Ungolfed:

# usage: echo 1|perl sun.pl

map {
    $_ = $r || O;  # no strict: o is "o". On the first run $r is not defined
    s/^|$/ /mg;    # overwriting $_ saves characters on these regexes
    s/ (-*O-*) /-$1-/;
    $r = "\\$s|$s/
$_
/$s|$s\\";         # Embedded newlines save 1B vs \n. On the first run $s is not defined.
    $s .= $"
} 1..<>;
say $r
alexander brett
la source
1

Prolog, 219 octets

Non, ce n'est pas une langue de golf. Mais je pense que ce site a besoin de plus de Prolog.

s(N,N,N,79).
s(R,R,_,92).
s(R,C,N,47):-R+C=:=2*N.
s(N,_,N,45).
s(_,N,N,124).
s(_,_,_,32).
c(_,C,N):-C>2*N,nl.
c(R,C,N):-s(R,C,N,S),put(S),X is C+1,c(R,X,N).
r(R,N):-R>2*N.
r(R,N):-c(R,0,N),X is R+1,r(X,N).
g(N):-r(0,N).

Testé avec swiplLinux. Invoquer comme ceci: swipl -s asciiSun.prolog; puis interrogez votre taille de soleil souhaitée:

?- g(3).
\  |  /
 \ | /
  \|/
---O---
  /|\
 / | \
/  |  \
true .

Ungolfed:

 % Args to sym/4 are row, column, N and the character code to be output at that location.
sym(N,N,N,79).
sym(R,R,_,'\\').
sym(R,C,N,'/') :- R+C =:= 2*N.
sym(N,_,N,'-').
sym(_,N,N,'|').
sym(_,_,_,' ').

 % Args to putCols/3 are row, column, and N.
 % Recursively outputs the characters in row from col onward.
putCols(_,C,N) :- C > 2*N, nl.
putCols(R,C,N) :- sym(R,C,N,S), put_code(S), NextC is C+1, putCols(R,NextC,N).

 % Args to putRows/2 are row and N.
 % Recursively outputs the grid from row downward.
putRows(R,N) :- R > 2*N.
putRows(R,N) :- putCols(R,0,N), NextR is R+1, putRows(NextR,N).

putGrid(N) :- putRows(0,N).
DLosc
la source
1

JavaScript (ES6), 142 140 134 117 octets

n=>(g=x=>x?`${t=` `[r=`repeat`](n-x--)}\\${s=` `[r](x)}|${s}/${t}
`+g(x):`-`[r](n))(n)+`O`+[...g(n)].reverse().join``

L'essayer

f=
n=>(g=x=>x?`${t=` `[r=`repeat`](n-x--)}\\${s=` `[r](x)}|${s}/${t}
`+g(x):`-`[r](n))(n)+`O`+[...g(n)].reverse().join``
i.addEventListener("input",_=>o.innerText=f(+i.value))
o.innerText=f(i.value=1)
<input id=i type=number><pre id=o>

Hirsute
la source