Croix de caractère


31

Je m'attendais à publier quelque chose de plus complexe comme mon premier casse-tête dans PCG, mais une question particulière, euh ... sur les devoirs sur Stack Overflow m'a inspiré à poster ceci. Ils veulent:

imprimez le modèle suivant pour tout mot donné contenant un nombre impair de lettres:

P           M
  R       A   
    O   R    
      G       
    O   R      
  R       A   
P           M 


Notez que les lettres sont un écart de chevalier dans le motif que vous devez imprimer. Ainsi, toutes les autres colonnes sont vides. - (Merci xnor de l' avoir signalé.)

Règles

  1. L'utilisation de C ++ est interdite. Comme je peux y lier cette question.
  2. Vous pouvez utiliser stdout, ou tout moyen de sortie rapide d'une chaîne (par exemple alert()en JavaScript).
  3. Comme toujours, le code le plus court l'emporte.

2
C'est dans les articles connexes sur le débordement de la pile: stackoverflow.com/q/5508110
Level River St

2
@flawr Je pense que cela signifie impair, comme dans un nombre pair.
NinjaBearMonkey

31
Dieu que je suis stupide, je pensais que c'était une sorte d'abréviation obscure d'informaticien =)
flawr

2
@jpjacobs: octets, sauf si la question dit explicitement le contraire.
Dennis

2
Un programme entier ou juste une fonction? (très intelligent de ma part de répondre d'abord et de poser cette question plus tard ...)
Rodolfo Dias

Réponses:


13

Pyth , 22

Vzjdm?@zd}N,dt-lzd\ Uz

Tester:

$ pyth -c 'Vzjdm?@zd}N,dt-lzd\ Uz' <<< "CODE-GOLF"
C               F
  O           L  
    D       O    
      E   G      
        -        
      E   G      
    D       O    
  O           L  
C               F

Explication:

(Implicit)                  z = input()
(Implicit)                  d = ' '
Vz                          for N in range(len(z)):
  jd                            print(d.join(
    m                               map(lambda d:
     ?@zd                                        z[d] if
         }N                                      N in
           ,dt-lzd                                    (d,len(z)-d-1) else
      \                                          " ",
     Uz                                          range(len(z)))))

Pas de complément en Pyth?
xnor

@xnor Non, mais cela n'aiderait pas. Supposons que le ~bit ne soit pas en Pyth. Ensuite, nous pourrions passer t-lzdà +lz~d- encore 5 caractères.
isaacg

Vzest une astuce intéressante: je ne savais pas que cela U<string>donnait range(len(<string>)).
FryAmTheEggman

Oui, c'est une fonctionnalité intéressante. Fonctionne de cette façon sur les listes aussi, mais pas nécessairement sur les tuples. EDIT: Oups, cela manque dans la documentation. Je vais l'ajouter. Désolé.
isaacg

20

APL ( 37 35 34 27)

↑{∊2↑¨⍵↑¨I}¨↓(+∨⌽)∘.=⍨⍳⍴I←⍞

Il prend la saisie du clavier, comme ceci:

      ↑{∊2↑¨⍵↑¨I}¨↓(+∨⌽)∘.=⍨⍳⍴I←⍞
CODE-GOLF
C               F 
  O           L   
    D       O     
      E   G       
        -         
      E   G       
    D       O     
  O           L   
C               F 

7
Tous mes votes positifs appartiennent à APL.
Nit

13

Python 2-94 90 89 88

s=input()
L=len(s)
R=range(L)
for i in R:print" ".join([s[j]," "][j!=i!=L+~j]for j in R)

Contribution:

"CODE-GOLF"

Sortie:

C               F
  O           L  
    D       O    
      E   G      
        -        
      E   G      
    D       O    
  O           L  
C               F

J'écrivais juste la même chose. Ma seule amélioration est i in[j,L+~j].
2014 à 7h08

@xnor: a trouvé une condition encore plus courte. ;)
Falko

Intelligent. Vous pouvez toujours le faire L+~j.
xnor

@xnor: Ah, vous avez raison. J'oublie toujours le +~truc ...
Falko

Pouvez-vous faire for i in R:print" ".join([s[j]," "][j!=i!=L+~j]for j in R)pour enregistrer un personnage? (Je n'ai pas accès à Python 2 pour tester.)
xnor

11

Python 3:75 caractères

s=input()
i=n=len(s)
while i:i-=1;a=[" "]*n;a[i]=s[i];a[~i]=s[~i];print(*a)

Pour la ligne i, nous commençons par une liste d'espaces et définissons les entrées ide l'avant et de l'arrière pour qu'elles soient égales aux lettres de la chaîne d'entrée. Ensuite, nous imprimons le résultat.

Les chaînes Python sont immuables, il adoit donc s'agir d'une liste de caractères à la place. La liste adoit être initialisée à l'intérieur de la boucle ou les modifications seront reportées entre les boucles. Nous utilisons print(*a)pour imprimer chaque caractère de la liste, séparés par des espaces, ce qui nécessite Python 3.

Les lignes de sortie sont symétriques, donc nous pouvons avoir un icompte à rebours plutôt que vers le haut en utilisant une boucle while.

>>> CODE-GOLF
C               F
  O           L  
    D       O    
      E   G      
        -        
      E   G      
    D       O    
  O           L  
C               F

Il fonctionne également pour un nombre pair de lettres.

>>> CODEGOLF
C             F
  O         L  
    D     O    
      E G      
      E G      
    D     O    
  O         L  
C             F

En convertissant cela en Pyth, je reçois VlzJ*]dlz=@JN@zN=@Jt_N@_zNjdJce qui est de 29 octets ... Je suppose que je vais devoir essayer autre chose pour battre APL. De plus, +1 pour la preuve que Python 3 peut
surpasser

@fry Python 3 surpasse généralement 2 selon mon expérience. Même si rien ne change ailleurs, la plupart des défis donnent une entrée et attendent une sortie, et len("raw_input()") + len("print ") > len("input()") + len("print()").
undergroundmonorail

@undergroundmonorail Eh bien, le problème est que cela input() est également valable en python 2 (il agit juste un peu différemment), donc à moins que l'entrée pour le défi ne soit assez stricte, python 2 gagnera généralement.
FryAmTheEggman

Wow, même avec Python 2 et print" ".join(a)votre code est plus court (82) que le mien.
Falko

@FryAmTheEggman Voir ma réponse - c'est une adaptation de l'autre réponse python, et elle est beaucoup plus courte que APL. Pyth n'aime vraiment pas assigner aux index, malheureusement.
isaacg

8

CJam, 27 25 octets

l_,S*:Sf{W):W2$tW~@tS}zN*

Essayez-le en ligne.

Exemple d'exécution

$ cjam <(echo 'l_,S*:Sf{W):W2$tW~@tS}zN*') <<< CROSS; echo
C       S 
  R   S   
    O     
  R   S   
C       S 

Comme l'exemple dans la réponse, chaque ligne a un espace de fin.

Comment ça marche

                             " N := '\n'; R := []; S = ' '; W := -1 ";
l                            " Q := input()                         ";
 _,S*:S                      " S := len(Q) * S                      ";
       f{            }       " for each C in Q:                     ";
                             "   T := S                             ";
         W):W                "   W += 1                             ";
             2$t             "   T[W] := C                          ";
                W~@t         "   T[~W] := C                         ";
                             "   R += [T]                           ";
                    S        "   R += [S]                           ";
                      z      " R := zip(R)                          ";
                       N*    " R := N.join(R)                       ";
                             " print R                              ";

1
Désolé, c'est fondamentalement une «excellente réponse! commentaire, mais je dû dire qu'il n'a jamais, jamais , aurait eu pour moi de construire la boîte par des colonnes plutôt que par des lignes.
FryAmTheEggman

4

Java - 168

Une simple boucle imbriquée, il n'y a rien de vraiment spécial ici.

class C{public static void main(String[]a){int b=-1,c=a[0].length()-1,d;for(;b++<c;)for(d=-1;d++<c;)System.out.print((b==d|b==c-d?a[0].charAt(d):" ")+(c==d?"\n":""));}}

Avec des sauts de ligne:

class C{
    public static void main(String[]a){
        int b=-1,c=a[0].length()-1,d;
        for(;b++<c;)
            for(d=-1;d++<c;)
                System.out.print(
                    (b==d|b==c-d?a[0].charAt(d):" ")+
                    (c==d?"\n":""));
    }
}

4

Pure Bash, 94 octets

l=${#1}
for((;t<l*l;t++));{
((x=t%l))||echo
((x-t/l&&x+t/l+1-l))&&printf \ ||printf ${1:x:1}
}

1
Trop de t%lcalculs. Enregistrez-le lors de la première utilisation dans une variable, ((x=t%l))puis utilisez la variable pour la réduire à 94 caractères.
manatwork

Ah oui, je l'avais fait pour x=t%let y=t/lc'était plus long ... je n'ai pas eu l'idée de n'utiliser que x
Digital Trauma

4

Rubis, 64

f=->w{x=w.size
x.times{|i|y=" "*x
y[i],y[~i]=w[i],w[~i]
puts y}}

Explication

  • L'entrée est considérée comme l'argument d'un lambda. Il attend a String.
  • Dans une boucle qui traverse tous les caractères du mot ( nau total):
    • Créez une chaîne composée d' nespaces.
    • Remplacez les espaces ith et n-ith ( ~i, merci xnor) par les caractères ith et n-ith de l'entrée.
    • Imprimer la ligne

7
Félicitations pour avoir publié la 25 000e réponse! :) (En fait, je ne suis pas sûr à 100%, c'est celui-ci, en raison de la mise en cache. Mais c'était la dernière réponse, quand j'ai vu pour la première fois "25 000 réponses" dans les statistiques du site.)
Martin Ender

2
Vous pouvez faire -i-1comme complément de bits ~i.
2014

C'est très intelligent, merci!
britishtea

2
Avec cette approche, il semble en fait avantageux d'utiliser stdin au lieu d'un lambda: gets.size.times{|x|u=?\s*~/$/;u[x]=$_[x];u[~x]=$_[~x];puts u}(suppose que l'entrée n'est pas terminée par une nouvelle ligne, par exemple echo -n CODE-GOLF). On peut alors faire un usage supplémentaire de .charspour sauvegarder un autre personnage:x=0;gets.chars{|r|u=?\s*~/$/;u[x]=r;u[~x]=$_[-x+=1];puts u}
Ventero

4

JavaScript (E6) 101 95129136

modifier espacement des lettres incorrect. Fixé.
Édition Plus simple et plus courte en utilisant des boucles classiques
Pour une fonction, sortie via popup.

F=a=>{
  for(l=a.length+1,i=s=o='';++i<l;s='\n')
    for(j=0;++j<l;)
      o+=s+((s=' ')+a)[j==i|i+j==l&&j]
  alert(o)
}

Version précédente utilisant .map

F=a=>alert([...a].map((c,p)=>
  --q<p
  ?B(q)+a[q]+B(p-q-1)+c 
  :B(p)+c+(p-q?B(q-p-1)+a[q]:'')
,B=n=>' '.repeat(n),q=a.length).join('\n'))

Test dans la console FireFox / FireBug

F('Java-Script')

Sortie

J                   t
  a               p  
    v           i    
      a       r      
        -   c        
          S          
        -   c        
      a       r      
    v           i    
  a               p  
J                   t

2
Cela n'a pas assez d'espacement horizontal - il devrait y avoir des colonnes de tous les espaces entre chaque colonne avec des lettres.
isaacg

4

Befunge-93, 68 71

:~:84*-!#@#v_\:2*\4+p1+
::+\4+g:!| >$1+0:>p1-::
00+4\*2:\<>0p#:- ^#2g

Vous pouvez le tester ici . Il y aura une boîte de dialogue d'entrée à chaque passage ~; entrez votre mot un caractère à la fois (cela dit que l'entrée est «klunky» après tout), en terminant par un espace.

Il n'imprimera pas sur la console; ce ne serait pas Befunge sans un soupçon d'auto-modification, après tout! Au lieu de cela, il modifiera sa propre grille pour afficher le message. Une fois terminé, la grille ressemblera à ceci:

 ~:84*-!#@#v_\:2*\4+p1+
::+\4+g:!| >$1+0:>p1-::
00+4\*2:\<>0p#:- ^#2g

c               f      
  o           l        
    d       o          
      e   g            
        -              
      e   g            
    d       o          
  o           l        
c               f

(Notez le noble sacrifice de la cellule à (0,0), une fois que nous savons que le pointeur n'y ira plus, dans le but de stocker une donnée.)

Il fonctionne également avec des entrées de même longueur. Notez que, puisque Befunge-93 est limité à une grille 80x25, la taille d'entrée est limitée à 21 caractères si vous l'exécutez dans un interpréteur Befunge-93. L'exécuter en tant que Befunge-98 devrait supprimer cette limite.

Modifier - Maintenant, cela fonctionne plus dans le sens de la sortie prévue, au détriment de seulement trois caractères de longueur.


Notez que les lettres sont séparées par une colonne vierge. Les lettres sont relativement en forme de L.
sampathsris

Zut! Cela a compliqué les choses de manière assez significative. Je pense que je peux sauver cela, mais cela ajoutera à la taille finale ... eh bien.
Kasran du

4

Javascript 102 84 85

Edit: a dû fixer l'espacement. Plus si petit.

function p(s){for(i in s){o='';for(n in s)o+=(n==i?s[n]:n==s.length-1-i?s[n]:' ')+' ';console.log(o)}}

p('Thanks-Dennis')

T                       s
  h                   i
    a               n
      n           n
        k       e
          s   D
            -
          s   D
        k       e
      n           n
    a               n
  h                   i
T                       s

Cela n'a pas suffisamment d'espacement horizontal.
Dennis

1
Wow, plus court que le mien et n'utilisant même pas ES6. +1
Scimonster du

Mieux, mais l'espacement est toujours faux (regardez le X). De plus, sauf indication contraire dans la question, vous devez écrire un programme ou une fonction. Les extraits de code avec des variables codées en dur sont généralement désapprouvés.
Dennis

1
Et tu ne peux pas le faire function(s)puisque tu ne récrères pas?
Zacharý

3

CJam, 38 36 35 34 32 octets

l:I,,_f{f{_2$=@2$+I,(=|\I=S?S}N}

Testez-le ici.Ceci lit le mot d'entrée de STDIN. Il fonctionne également pour un nombre pair de caractères. Cela imprime une colonne d'espaces de fin, mais je ne vois rien dans les règles contre cela.

Explication

l:I,,_f{f{_2$=@2$+I,(=|\I=S?S}N}
l:I                              "Read input and store it in I.";
   ,                             "Get string length.";
    ,_                           "Turn into range and duplicate.";
      f{                       } "Map block onto first range, with second range on the stack.";
        f{                   }   "Map block onto second range, with first iterator in stack.
                                  Each invocation of this block will start with grid coordinates
                                  y and x on the stack (x on top).";
          _2$=                   "Duplicate x, duplicate y, check for equality.";
              @2$+               "Pull up y, duplucate x, add,";
                  I,(=           "Check if that's one less than the string length.";
                      |          "Bitwise or between conditions.";
                       \         "Swap condition and x.";
                        I=       "Take x'th character from the string.";
                          S?     "Push a space and select character depending on condition.";
                            S    "Push another space.";
                              N  "Push a line feed.";

Le contenu de la pile est imprimé automatiquement à la fin du programme.


Mon cher CJam, vous venez d'être battu par APL. ^ _ ^
vaxquis

@vaxquis J'ai été surpris d'avoir pu le battre deux fois en premier lieu. Ce problème semble beaucoup plus adapté à APL et co qu'aux langages basés sur la pile.
Martin Ender

2
enfin, au moins c'est plus facile d'écrire l:I,,_f{f{_2$=@2$+I,(=|\I=S?S}N}sur une serviette que ↑{∊2↑¨⍵↑¨I}¨↓(+∨⌽)∘.=⍨⍳⍴I←⍞... gloussement
vaxquis

Eh bien, quelqu'un d'autre a réussi à me battre en utilisant CJam, et je ne peux pas raccourcir mon programme, donc CJam m'a finalement battu. (Mais Pyth obtient la couronne.) (Cela dit, @vaxquis, APL est beaucoup plus facile à lire que la plupart des autres langues utilisées ici, certainement une fois que vous connaissez les 60 caractères environ, et certainement par rapport à Pyth ou CJam ou même J.)
marinus

3

C, 105

deux façons légèrement différentes de le faire.

c,i,j;main(int l,char**v){for(l=strlen(v[1]);j-l;)putchar((c=v[1][i++])?i-1-j&&l-i-j?32:c:(i=0,j++,10));}

i,j;main(int l,char**v){for(l=strlen(v[1]);j-l;i++)putchar((l-i)?i-j&&l-i-j-1?32:v[1][i]:(i=-1,j++,10));}

Si vous souhaitez ajouter des espaces supplémentaires, remplacez-les putchar(par printf(" %c",5 caractères supplémentaires.


3

J - 36 30 octets:

Edit: 6 caractères plus courts, les crédits vont à @algorithmshark .

(1j1#"1' '&,({~](*>.*&|.)=)#\)

par exemple:

   (1j1#"1' '&,({~](*>.*&|.)=)#\) 'Code-Golf'
C               f
  o           l  
    d       o    
      e   G      
        -        
      e   G      
    d       o    
  o           l  
C               f

Bonus: fonctionne également avec des chaînes de longueur égale:

   (1j1#"1' '&,({~](*>.*&|.)=)#\) 'CodeGolf'
C             f
  o         l  
    d     o    
      e G      
      e G      
    d     o    
  o         l  
C             f

3

Prolog - 240 octets

:-initialization m.
+[]. +[H|T]:-(H=' ';!),+T.
+[H|T]+I+X:-0=:=I,X=H;+T+(I-1)+X.
+L+I+C+S:-L=:=I;S=[D|E],+C+I+B,+C+(L-I-1)+B,+B+2*I+D,+L+(I+1)+C+E,+B,writef('%s\n',[B]).
-X:-get_char(C),(C='\n',X=[];X=[C|Y],-Y).
m:- -X,length(X,L),+L+0+_+X.

Invocation:

$ echo "Code-Golf" | swipl -qf c.pl
C               f
  o           l
    d       o
      e   G
        -
      e   G
    d       o
  o           l
C               f

Lisible:

:- initialization(main).

vars_to_spaces([]).
vars_to_spaces([' '|T]) :- vars_to_spaces(T).
vars_to_spaces([_|T]) :- vars_to_spaces(T).

get_index([Head|_], Index, Result) :-
    0 =:= Index,
    Result = Head.
get_index([_|Tail], Index, Result) :-
    get_index(Tail, Index-1, Result).

print_loop(Length, Index, Board, String) :-
    Length =:= Index;
    String = [FirstChar|RestString],
    get_index(Board, Index, Line),
    get_index(Board, Length-Index-1, Line),
    get_index(Line, 2*Index, FirstChar),
    print_loop(Length, Index+1, Board, RestString),
    vars_to_spaces(Line),
    writef('%s\n', [Line]).

get_line(Line) :-
    get_char(C),
    (   C = '\n', Line = [];
        Line = [C|More], get_line(More)).

main :-
    get_line(String),
    length(String, Length),
    print_loop(Length, 0, _, String).

3

Canevas , 5 octets

\\:⇵n

Essayez-le ici!

Explication:

\      create a diagonal of the input
 \     create an even steeper diagonal of that
  :⇵   reverse a copy of it vertically
    n  overlap the two

3

R , 99 98 93 89 octets

m=ifelse(diag(l<-length(w<-el(strsplit(scan(,''),'')))),w,' ')
write(pmax(m,m[,l:1]),1,l)

Essayez-le en ligne!

La ligne 1 lit la chaîne d'entrée, la divise en caractères, stocke sa longueur et crée une matrice avec le mot sur sa diagonale principale - les lettres du mot sont superposées sur une matrice d'identité (et répétées par défaut pour correspondre à sa longueur) et uniquement celles qui correspondent Les 1 sont conservés, les autres étant remplacés par des espaces.

La ligne 2 imprime une matrice formée d'éléments de la matrice diagonale ou de sa version à miroir horizontal, selon la valeur la plus élevée.

−2 + 1 = −1 octet grâce à JayCe

−4 octets grâce à Giuseppe


1
Doux! Et belle explication.Vous pouvez économiser 2 octets
JayCe

1
en regardant les autres réponses et la question - Il semble que la matrice devrait être plus grande (espace supplémentaire) - la sortie ne devrait pas être une matrice carrée ..
JayCe

@JayCe Merci pour les 2 octets! Et merci pour le commentaire sur le formatage, vous avez probablement raison (bien que les règles puissent être plus claires à ce sujet). Heureusement, il suffisait de mettre un espace dans le séparateur pendant l'impression.
Robert Hacken

89 octets utilisantpmax et intégrant quelques affectations supplémentaires.
Giuseppe

@ Giuseppe Merci! Malheureusement, toujours pas assez pour battre J.Doe de solution
Robert Hacken

2

C # ( 214 212)

(Certainement mal) Version golf:

using System;class A{static void Main(){char[]a,w=Console.ReadLine().ToCharArray();int l=w.Length,i=0;for(;i<l;i++){a=new string(' ',2*l-1).ToCharArray();a[2*i]=w[i];a[2*l-2*i-2]=w[l-i-1];Console.WriteLine(a);}}}

Version non-golfée:

using System;

class A
{
  static void Main()
  {
    char[] a, w = Console.ReadLine().ToCharArray();
    int l = w.Length, i = 0;
    for (; i < l; i++)
    {
      a = new string(' ', 2 * l - 1).ToCharArray();
      a[2 * i] = w[i];
      a[2 * l - 2 * i - 2] = w[l - i - 1];
      Console.WriteLine(a);
    }
  }
}

Tous les conseils, astuces, astuces ou remarques sont les bienvenus, car c'est ma première tentative chez CodeGolf. Je voulais juste l'essayer, même si je sais que ma longueur d'octet C # ne sera même pas proche de doubler les meilleures solutions;)

Et comment comptez-vous vos octets? Je viens de publier ce qui précède dans une fenêtre de surveillance rapide et je l'ai fait .Length. Je pourrais écrire un petit programme pour compter les octets pour moi, mais je parie qu'il existe un moyen plus simple que je ne connais pas encore.


Vous pouvez enregistrer deux octets en supprimant les espaces dans for(;i < l;i++).
Beta Decay

J'utilise aussi ce pour mon comptage d'octets.
Beta Decay

@BetaDecay Ah génial, j'ai dû les ignorer. Et merci pour le lien!
InvisiblePanda

2

JavaScript (ES6) - 185 177 175 170 octets

f=n=>{return s='  ',r='repeat',n=[...n],l=n.length,j=l/2-.5,[...h=n.slice(0,j).map((c,i)=>s[r](i)+c+s[r](l-2-(i*2))+' '+n[l-i-1]),s[r](j)+n[j],...h.reverse()].join('\n')}

Mettez ceci dans la console Firefox et exécutez comme f('PROGRAM'):

P           M
  R       A
    O   R
      G
    O   R
  R       A
P           M

f("CODE-GOLF"):

C               F
  O           L
    D       O
      E   G
        -
      E   G
    D       O
  O           L
C               F


J'ai vu celui-là aussi.
Scimonster

2

Mathematica, 149 octets

FromCharacterCode@Flatten[Append[Riffle[#,32],10]&/@MapThread[Max,{#,Reverse@#,ConstantArray[32,Dimensions@#]},2]&@DiagonalMatrix@ToCharacterCode@#]&

Entrée passée en paramètre à la fonction; renvoie la chaîne de sortie. Il y a une nouvelle ligne à la fin de la sortie.

Explication: Nous créons une matrice diagonale avec la chaîne, puis nous en créons une copie retournée verticalement en utilisant Reverse@#pour inverser les lignes. Ensuite, nous avons une troisième matrice de mêmes dimensions contenant seulement 32 (espace ascii). Nous utilisons MapThreadpour prendre le max élément par élément de ces 3 matrices. Enfin, nous avons des Riffleespaces dans chaque ligne, Appendune nouvelle ligne à la fin et Flattenle résultat.


2

C , 119

i,j;main(int l,char**v){l=strlen(v[1]);for(i=0;i<l;i++){for(j=0;j<l;j++)putchar((i-j)*(j-l+i+1)?32:v[1][j]);puts("");}}

Cela pourrait ne pas être compilé en C ++, donc j'espère que je n'ai pas violé les règles :)


1. La sortie est actuellement incorrecte. Il devrait y avoir un espace entre les lettres. 2. i=0et j=0n'est pas nécessaire, car les variables globales sont initialisées à zéro. 3. Vous pouvez utiliser à la main(l,v)char**v;place de main(int l,char**v). 4. Si vous mettez ià jour en tant que i+=puts(""), vous pouvez vous débarrasser des crochets de la boucle extérieure.
Dennis

2

Perl - 90

Il pourrait être possible d'en extraire d'autres caractères:

($j=$i++%8)==7?++$k&&print"\n":print$j+1==$k||7-$j==$k?"$_ ":"  "for split//,($_ x y///c)

89 + 1 pour-n .

Courir avec:

echo "program" | perl -nE'($j=$i++%8)==7?++$k&&print"\n":print$j+1==$k||7-$j==$k?"$_ ":"  "for split//,($_ x y///c)'

Sortie:

p           m
  r       a
    o   r
      g
    o   r
  r       a
p           m

2

T-SQL: 180

Prendre l'entrée de la variable @i

DECLARE @s VARCHAR(MAX)=REPLICATE('  ',LEN(@i)),@ INT=1a:PRINT STUFF(STUFF(@s,@*2-1,1,SUBSTRING(@i,@,1)),LEN(@i)*2-(@*2)+1,1,SUBSTRING(@i,LEN(@i)-@+1,1))SET @+=1IF @<=LEN(@i)GOTO A

Cela place des caractères simples dans / décrémentant du début et de la fin dans une chaîne d'espaces.

Résultat du test

DECLARE @i VARCHAR(MAX)='Super Large'
DECLARE @s VARCHAR(MAX)=REPLICATE('  ',LEN(@i)),@ INT=1a:PRINT STUFF(STUFF(@s,@*2-1,1,SUBSTRING(@i,@,1)),LEN(@i)*2-(@*2)+1,1,SUBSTRING(@i,LEN(@i)-@+1,1))SET @+=1IF @<=LEN(@i)GOTO A
S                   e 
  u               g   
    p           r     
      e       a       
        r   L         

        r   L         
      e       a       
    p           r     
  u               g   
S                   e 

2

PowerShell 118 102 97

($x=[char[]]"$args")|%{$i++;$y=[char[]]" "*$x.Count;$y[$i-1]=$x[$i-1];$y[-$i]=$x[-$i];$y-join' '}

Les sorties:

PS C:\PowerShell> .\cross.ps1 SWORD
S       D
  W   R
    O
  W   R
S       D


2

JavaScript (Node.js) , 81 octets

f=s=>[...s].map((_,i,a)=>a.map((c,j)=>j==i|j==s.length+~i?c:' ').join` `).join`
`

EDIT : -1 Merci Joe King. Je n'ai pas vu que le TIO donne de la pâte directe préformatée pour CG.

Essayez-le en ligne!


btw, l'excès de code pour exécuter le code dans TIO peut aller dans le pied de page du programme. Cela permet de déterminer le nombre d'octets correct et d'utiliser le format de réponse PPCG automatisé plus facilement. par exemple Essayez-le en ligne!
Jo King

-i-1peut être+~i
Jo King

1

C # 208

static void Main()
{
string s=Console.ReadLine(),t="";
int n=s.Length;
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(i==j)t+=s[i];
else if(i==n-j-1)t+=s[n-i-1];
t+=" ";
}
t+="\n";
}
Console.WriteLine(t);
}

Enregistrez 11 personnages précieux avec t+=i==j?s[i]:i==n-j-1?s[n-i-1]:"";.
sampathsris

Pouvez-vous supprimer ces nouvelles lignes?
Zacharý


1

Peu importe combien de temps, il doit toujours y avoir une réponse dans ...

Java - 289 234 octets

public static void main(String[]a){int l=a.length-1,i=0,j;for(;i<=l;i++){for(j=0;j<=l;j++){if(j==i)System.out.print(a[i]);else if(i==l-j)System.out.print(a[j]);else System.out.print(" ");System.out.print(" ");}System.out.println();}}}

Ungolfed:

    class A {

    public static void main(String[] a) {
        int l = a.length - 1, i = 0, j;
        for (; i <= l; i++) {
            for (j=0; j <= l;j++) {
                if (j == i)
                    System.out.print(a[i]);
                else if (i == l-j)
                    System.out.print(a[j]);
                else
                    System.out.print(" ");
                System.out.print(" ");
                }            
            System.out.println();
        }
    }
}

Le résultat, mal fait, est:

P           M 
  R       A   
    O   R     
      G       
    O   R     
  R       A   
P           M 

Ajout de l' import java.util.Scannerintérieur du code parce que je ne me souviens jamais si les importations comptent pour le nombre d'octets ... Merde, je suis vraiment nul.


2
Les importations comptent. C'est en partie à cause de la syntaxe d'importation et d'alias de Python: from math import floor as fqui est un peu tricheuse

Vous devriez être en mesure d'enregistrer un tas de caractères en combinant tous les System.out.printappels en un seul, en utilisant quelques opérateurs ternaires.
DLosc

@DLosc Pourriez-vous me donner quelques exemples?
Rodolfo Dias du

1
Oui, en fait, la réponse de Geobits est un parfait exemple - voir le contenu de l' System.out.printappel à la fin.
DLosc

1
@RodolfoDias Ne vous sentez pas de cette façon. Mes premiers golfs à Java ont été terribles , et je peux toujours me raser normalement une bonne partie de mes "premières révisions" si je regarde bien;)
Geobits

1

C # (192/170)

using System;class P{static void Main(){var s=Console.ReadLine();int x,y,l=s.Length;for(x=0;x<l;x++){for(y=0;y<l;y++)Console.Write(x==y||l-x==y+1?s.Substring(x,1):" ");Console.Write("\n");};}}

Ou, en tant que "Main () uniquement":

static void Main(){var s=Console.ReadLine();int x,y,l=s.Length;for(x=0;x<l;x++){for(y=0;y<l;y++)Console.Write(x==y||l-x==y+1?s.Substring(x,1):" ");Console.Write("\n");};}
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.