텍스트 큐브 ݀


17

지난번 에 텍스트 사각형을 만들었지 만 이제 텍스트 큐브 를 만들 수 있습니까?

도전

문자열이 주어지면 큐브 형태로 문자열을 출력하십시오.

문자열에 항상 2 자 이상이 있고 인쇄 가능한 ASCII 문자 만 있다고 가정 할 수 있습니다.

텍스트 큐브를 만드는 방법

끔찍한 mspaint skills.png

테스트 사례

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

파이썬에서 참조 구현

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

규칙

  • 이것은 이므로 바이트 단위의 최단 답변이 이깁니다! 타이 브레이커가 가장 많이지지됩니다.
  • 표준 허점은 허용되지 않습니다.
  • 후행 줄 바꾸기 및 후행 공백이 허용됩니다.

후행 공백이 허용됩니까?

@ 닐 예. (15 자)
acrolith

챌린지 타이틀의 추가 캐릭터는 무엇입니까?
AdmBorkBork

@TimmyD "텍스트 큐브"는 14 자 길이이며 제목은 15 자 이상이어야하므로 작은 점을 추가했습니다. 나는 이것이 이것이라고 생각합니다.
acrolith

그래. 그것은으로 나타 훨씬 더 큰 원 내 컴퓨터에서 IE에서, 따라서 내 질문에.
AdmBorkBork

답변:



4

파이썬 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

파이썬 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)

203 바이트입니다. 또한로 교체 raw_input()하여 4 바이트를 절약 할 수 있습니다 input().
acrolith

그래, 고마워!
Joshua de Haan

x*(q)? 파 렌스를 제거 할 수 있어야합니다.
Value Ink

당신 말이 맞아, 어리석은 날;) 지금 고치기 haha
Joshua de Haan

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

3

x86 (IA-32) 머신 코드, 126 바이트

16 진 덤프 :

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

이것은 약간 길기 때문에 먼저 C 코드를 줄 것입니다.

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);
}

n입력 문자열의 길이는 다음과 같습니다 .

출력 영역의 크기는 2n(너비) x 2n-1(높이)입니다. 먼저, 공백으로 모든 것을 채우고 종료 널 바이트를 추가합니다. 그런 다음 출력 영역에서 11 개의 직선을 따라 이동하고 텍스트로 채 웁니다.

  • 2 줄은 줄 끝 바이트 (= 10)로 채워집니다.
  • 9 줄은 입력 문자열의 연속 바이트로 채워집니다.

각 줄은 시작 오프셋과 보폭의 두 숫자로 표시됩니다. offsets액세스를 "쉽게"만들기 위해 둘 다 배열에 넣었습니다 .

흥미로운 부분은 배열을 채우는 것입니다. 배열의 항목 순서는 중요하지 않습니다. 레지스터 충돌 수를 최소화하기 위해 다시 정렬하려고했습니다. 또한 이차 방정식은 계산 방법을 선택할 때 약간의 자유가 있습니다. 나는 뺄셈의 수를 최소화하려고 노력했다.LEA 명령 ).

조립 소스 :

    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;

여기에서는 바이트 곱셈을 사용하여 입력 문자열의 길이를 127로 제한했습니다. 이렇게하면 레지스터가 방해받지 않습니다. 대신 edx제품이 계산 ax됩니다.

사소한 결함 : 배열을 채울 때 문자열의 길이가 1 씩 줄어 듭니다. 그래서 루프 종료 조건을 조정했습니다.

    jns myout

-1로 카운트 다운됩니다.


3

루비, 148144 바이트

n플래그 에서 +1 바이트 가독성을 위해 세미콜론 대신 줄 바꾸기를 표시합니다 (동일한 기능).

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

그렇게하세요 입력은 줄 바꿈이없는 STDIN 행이므로 파일에서 파이프해야합니다.

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

자바 스크립트, 225 198 바이트

@Neil 덕분에 27 바이트 절약

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`
`
  • .concat 대신 [...]
  • for 루프 대신 [...] + map
  • 변수를 함수 매개 변수로 이동하여 하나의 명령문 만
  • lt에 대한 더 나은 초기화

원래 답변 :

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
멋지지만 골프를 칠 수는 있지만 : 주석에 줄 바꿈을 넣을 수 없기 때문에 (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`사용 \n합니다.
Neil

0

자바 7, 283 바이트

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',' '));}}

여기 사용해보십시오!

언 골프 드 :

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',' '));
    }
}
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.