Ein Textwürfel text


17

Das letzte Mal, als Sie ein Quadrat aus Text erstellt haben, können Sie jetzt einen Würfel aus Text erstellen?

Die Herausforderung

Geben Sie bei einer gegebenen Zeichenfolge die Zeichenfolge in Form eines Würfels aus.

Sie können davon ausgehen, dass die Zeichenfolge immer 2 Zeichen oder mehr und nur druckbare ASCII-Zeichen enthält.

So erstellen Sie einen Textwürfel

schreckliche mspaint skills.png

Testfälle

Input:
Test

Output:
   Test
  e  ss
 s  e e
tseT  T
s  e e
e  ss
Test

Input:
Hello, world!

Output:
            Hello, world!
           e           dd
          l           l l
         l           r  r
        o           o   o
       ,           w    w

     w           ,      ,
    o           o       o
   r           l        l
  l           l         l
 d           e          e
!dlrow ,olleH           H
d           e          e
l           l         l
r           l        l
o           o       o
w           ,      ,

,           w    w
o           o   o
l           r  r
l           l l
e           dd
Hello, world!

Input:
Hi

Output:
 Hi
iHH
Hi

Referenzimplementierung in Python

text = raw_input("Enter a string: ")

print " " * (len(text) - 1) + text

spaces = len(text) - 2
_spaces = spaces

for i in range(1, len(text) - 2 + 1):
    print " " * spaces + text[i] + " " * _spaces + text[(i + 1) * -1] + " " * (_spaces - spaces) + text[(i + 1) * -1]
    spaces -= 1

print text[::-1] + " " * _spaces + text[0]

spaces = _spaces - 1

for i in range(1, len(text) - 2 + 1):
    print text[(i + 1) * -1] + " " * _spaces + text[i] + " " * spaces + text[i]
    spaces -= 1

print text

Regeln

  • Das ist , also gewinnt die kürzeste Antwort in Bytes! Tiebreaker ist am meisten aufgeregt.
  • Standardlücken sind nicht zulässig.
  • Es sind abschließende Zeilenumbrüche und abschließende Leerzeichen zulässig.

Sind nachgestellte Leerzeichen erlaubt?
Neil

@ Neil Ja. (15 Zeichen)
Acrolith

Nur neugierig, was ist mit den zusätzlichen Charakteren im Herausforderungstitel?
AdmBorkBork

@TimmyD "Ein Textwürfel" ist 14 Zeichen lang, der Titel muss mindestens 15 Zeichen lang sein, daher habe ich einen kleinen Punkt hinzugefügt. Ich denke, es ist das hier.
Acrolith

Ah, ok. Es zeigt sich als viel größerer Kreis in IE auf meinem Computer, daher meine Frage.
AdmBorkBork

Antworten:



4

Python 2, 228 223 221 203 199 195 189

t=input()
x=" "
l=len(t)-1
q=l-1
f=range(q,0,-1)
print x*l+t
for i in f:print x*i+t[l-i]+x*q+t[i]+x*(q-i)+t[i]
print t[::-1]+x*q+t[0]
for i in f:print t[i]+x*q+t[l-i]+x*(i-1)+t[l-i]
print t

Python 3, 192 188 182

t=input()
x=" "
l=len(t)-1
q=l-1
p=print
f=range(q,0,-1)
p(x*l+t)
for i in f:p(x*i+t[l-i]+x*q+t[i]+x*(q-i)+t[i])
p(t[::-1]+x*q+t[0])
for i in f:p(t[i]+x*q+t[l-i]+x*(i-1)+t[l-i])
p(t)

Das sind 203 Bytes. Auch können Sie auf 4 Bytes speichern durch Ersetzen raw_input()mit input().
Acrolith

Richtig, danke!
Joshua de Haan

x*(q)? Sie sollten in der Lage sein, die Parens zu entfernen, ja?
Value Ink

Du hast recht, du Idiot;) Behebung jetzt haha
Joshua de Haan

x*(i-1)->x*~-i
mbomb007

3

x86-Computercode (IA-32), 126 Byte

Hexdump:

60 8b f9 57 33 c0 f2 ae 5e 2b fe 4f 87 fa 8d 1c
12 8b c3 48 f6 e3 c6 04 07 00 48 c6 04 07 20 75
f9 8b ea 4d 53 8d 04 2a 50 53 8b c5 f6 e3 8d 44
68 01 50 53 2b c2 8b c8 50 4b 53 55 53 03 c5 50
f7 d3 53 50 53 95 f6 e2 6b c0 04 50 43 53 51 6a
01 4a 52 6a 01 50 6a ff 51 b0 0a 6a 0b 8b dc 59
8b 6c cb fc 88 04 2f 03 2c cb 89 6c cb fc 83 f9
0a 75 01 ac e2 ea 4a 79 e0 83 c4 58 61 c3

Das ist ein bisschen lang. Um es zu erklären, gebe ich zuerst C-Code:

void doit(const char* s, char out[])
{
    int n = strlen(s);
    int w = 2 * n;
    int h = w - 1;
    int m = n - 1;

    memset(out, ' ', h * w);
    out[h * w] = 0;

    int offset1 = n + m;
    int offset2 = w * m + 2 * m + 1; // 2 * n * n - 1
    int offset3 = offset2 - n; // 2 * n * n - n - 1
    int offset4 = 4 * n * m; // 4 * n * n - 4 * n

    int offsets[] = {
        offset3, -1,
        offset4, 1,
        m, 1,
        offset3, 1 - w,
        offset4, -w,
        offset2 - 1, -w,
        offset2 - 1, w - 1,
        m, w - 1,
        offset3, w,
        offset2, w,
        offset1, w,
    };

    do
    {
        char c = *s++;
        for (int i = 0; i < 11; ++i)
        {
            if (i == 9)
                c = '\n';
            int offset = offsets[i * 2];
            assert(offset > 0 && offset < w * h);
            out[offset] = c;
            offsets[i * 2] += offsets[i * 2 + 1];
        }
    } while (--n);
}

Hier nist die Länge der Eingabezeichenfolge.

Die Abmessungen des Ausgabebereichs sind 2n(Breite) mal 2n-1(Höhe). Zunächst wird alles mit Leerzeichen gefüllt (und ein abschließendes Null-Byte hinzugefügt). Anschließend bewegt es sich im Ausgabebereich entlang elf gerader Linien und füllt sie mit Text:

  • 2 Zeilen werden mit Zeilenende-Bytes gefüllt (= 10)
  • 9 Zeilen werden mit den aufeinanderfolgenden Bytes der Eingabezeichenfolge gefüllt

Jede Zeile wird durch zwei Zahlen dargestellt, einen Startoffset und einen Schritt. Ich habe beide in das Array gesteckt offsets, um den Zugriff "einfach" zu gestalten.

Der interessante Teil füllt das Array. Die Reihenfolge der Einträge im Array ist von geringer Bedeutung. Ich habe versucht, sie neu anzuordnen, um die Anzahl der Registerkonflikte zu minimieren. Außerdem haben quadratische Formeln eine gewisse Freiheit bei der Wahl der Berechnungsweise. Ich habe versucht, die Anzahl der Subtraktionen zu minimieren (da durch die flexible LEAAnweisung Additionen implementiert werden können ).

Versammlungsquelle:

    pushad;

    ; // Calculate the length of the input string
    mov edi, ecx;
    push edi;
    xor eax, eax;
    repne scasb;
    pop esi; // esi = input string
    sub edi, esi;
    dec edi;

    ; // Calculate the size of the output area
    xchg edi, edx;  // edx = n
                    // edi = output string
    lea ebx, [edx + edx]; // ebx = w
    mov eax, ebx;
    dec eax; // eax = h
    mul bl; // eax = w * h

    ; // Fill the output string with spaces and zero terminate it
    mov byte ptr [edi + eax], 0;
myfill:
    dec eax;
    mov byte ptr [edi + eax], ' ';
    jnz myfill;

    mov ebp, edx;
    dec ebp; // ebp = m

    ; // Fill the array of offsets
    push ebx; // w
    lea eax, [edx + ebp];
    push eax; // offset1
    push ebx; // w
    mov eax, ebp;
    mul bl;
    lea eax, [eax + 2 * ebp + 1];
    push eax; // offset2
    push ebx; // w
    sub eax, edx;
    mov ecx, eax; // ecx = offset3
    push eax; // offset3
    dec ebx;
    push ebx; // w - 1
    push ebp; // m
    push ebx; // w - 1
    add eax, ebp;
    push eax; // offset2 - 1
    not ebx;
    push ebx; // -w
    push eax; // offset2 - 1
    push ebx; // -w
    xchg eax, ebp; // eax = m
    mul dl;
    imul eax, eax, 4;
    push eax; // offset4
    inc ebx;
    push ebx; // 1 - w
    push ecx; // offset3
    push 1;
    dec edx; // edx = n - 1
    push edx;
    push 1;
    push eax;
    push -1;
    push ecx;

    ; // Use the array of offsets to write stuff to output
myout:
    mov al, '\n';
    push 11;
    mov ebx, esp;
    pop ecx;
myloop:
    mov ebp, [ebx + ecx * 8 - 4];
    mov [edi + ebp], al;
    add ebp, [ebx + ecx * 8];
    mov [ebx + ecx * 8 - 4], ebp;
    cmp ecx, 10;
    jne skip_read;
    lodsb;
skip_read:
    loop myloop;
    dec edx;
    jns myout;

    add esp, 11 * 8;

    popad;
    ret;

Ich habe hier Byte-Multiplikationen verwendet, um die Länge der Eingabezeichenfolge auf 127 zu begrenzen. Dadurch wird ein Überladen des Registers vermieden edx- axstattdessen wird das Produkt berechnet .

Ein kleiner Fehler: Beim Ausfüllen des Arrays wird die Länge des Strings um 1 verringert. Deshalb habe ich die Loop-Exit-Bedingung angepasst:

    jns myout

Es zählt bis -1 herunter.


3

Ruby, 148 144 Bytes

+1 Byte von der nFlagge. Zeigt Zeilenumbrüche anstelle von Semikolons zur besseren Lesbarkeit an (gleiche Funktionalität).

S=" "
X=S*s=$_.size-2
puts X+S+I=$_,(r=1..s).map{|i|c=I[~i];S*(s-i+1)+I[i]+X+c+S*~-i+c},I.reverse+X+I[0],r.map{|i|c=I[i];I[~i]+X+c+S*(s-i)+c},I

Laufen Sie so. Bei der Eingabe handelt es sich um eine STDIN-Zeile ohne nachfolgende Zeilenumbrüche. Daher muss sie wahrscheinlich aus der Datei weitergeleitet werden.

ruby -ne 'S=" ";X=S*s=$_.size-2;puts X+S+I=$_,(r=1..s).map{|i|c=I[~i];S*(s-i+1)+I[i]+X+c+S*~-i+c},I.reverse+X+I[0],r.map{|i|c=I[i];I[~i]+X+c+S*(s-i)+c},I'

1

Javascript, 225 bis 198 Bytes

27 Bytes dank @Neil eingespart

f=(s,l=s.length-2,d=' ',r='repeat',t=d[r](l))=>[d+t+s,...a=[...Array(l)].map((_,i)=>d[r](l-i)+s[i+1]+t+(p=s[l-i])+d[r](i)+p),[...s].reverse().join``+t+s[0],...a.map(v=>v.trim()).reverse(),s].join`
`
  • [...] statt .concat
  • [...] + map statt for loop
  • nur eine Anweisung durch Verschieben von Variablen als Funktionsparameter
  • bessere Initialisierung für l und t

Ursprüngliche Antwort:

f=s=>{l=s.length,d=' ',r='repeat',a=[],t=d[r](l-2)+s;for(i=1;i++<l-1;)a.push(d[r](l-i)+s[i-1]+d[r](l-2)+(p=s[l-i])+d[r](i-2)+p);console.log(d+[t].concat(a,[...t].reverse().join``+s[0],a.map(v=>v.trim()).reverse(),s).join`
`)}

1
Schön, obwohl golffähig: (s,l=s.length-2,d=' ',r='repeat',t=d[r](l))=>[d+t+s,...a=[...Array(l)].map((_,i)=>d[r](l-i)+s[i+1]+t+(p=s[l-i])+d[r](i)+p),[...s].reverse().join``+t+s[0],...a.map(v=>v.trim()).reverse(),s].join`\n`(mit, \nweil man in Kommentaren keine Zeilenumbrüche setzen kann).
Neil

0

Java 7, 283 Bytes

void a(String s){int h=s.length(),n=h*2-1,t=n-h,u=n-1;char[][]c=new char[n][n];for(int i=0;i<h;i++){c[0][t+i]=c[i][t-i]=c[t][t-i]=c[t+i][t]=c[t+i][u-i]=c[t-i][t+i]=c[t-i][u]=c[u][i]=c[u-i][0]=s.charAt(i);}for(int y=0;y<n;y++){System.out.println(new String(c[y]).replace('\0',' '));}}

Probieren Sie es hier aus!

Ungolfed:

void a(String s) {
    int length=s.length(),
        n=length*2-1,
        mid=n-length,
        doubleMid=n-1;
    char[][]c=new char[n][n];
    for(int i=0;i<length;i++) {
        c[0][mid+i]= 
        c[i][mid-i]=
        c[mid][mid-i]=
        c[mid+i][mid]=
        c[mid+i][doubleMid-i]=
        c[mid-i][mid+i]=
        c[mid-i][doubleMid]=
        c[doubleMid][i]=
        c[doubleMid-i][0]=s.charAt(i);
    }
    for(int y=0;y<n;y++){
        System.out.println(new String(c[y]).replace('\0',' '));
    }
}
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.