Animuj znalezienie środka

10

Biorąc pod uwagę niepusty ciąg, usuwaj pierwszy i ostatni znak, aż dojdziesz do jednego lub dwóch znaków.

Na przykład, jeśli ciąg był abcde, twój program powinien wydrukować:

abcde
 bcd
  c

Jeśli jednak tak jest abcdef, powinien zatrzymać się na dwóch znakach:

abcdef
 bcde
  cd

Końcowe znaki nowej linii i końcowe spacje na końcu każdej linii są opcjonalne. Możesz mieć tyle, ile chcesz lub nie mieć ich wcale.

Przypadki testowe

ABCDEFGHIJKLMNOPQRSTUVWXYZ -> ABCDEFGHIJKLMNOPQRSTUVWXYZ
                               BCDEFGHIJKLMNOPQRSTUVWXY 
                                CDEFGHIJKLMNOPQRSTUVWX  
                                 DEFGHIJKLMNOPQRSTUVW   
                                  EFGHIJKLMNOPQRSTUV    
                                   FGHIJKLMNOPQRSTU     
                                    GHIJKLMNOPQRST      
                                     HIJKLMNOPQRS       
                                      IJKLMNOPQR        
                                       JKLMNOPQ         
                                        KLMNOP          
                                         LMNO           
                                          MN            

ABCDEFGHIJKLMNOPQRSTUVWXYZ! -> ABCDEFGHIJKLMNOPQRSTUVWXYZ!
                                BCDEFGHIJKLMNOPQRSTUVWXYZ 
                                 CDEFGHIJKLMNOPQRSTUVWXY  
                                  DEFGHIJKLMNOPQRSTUVWX   
                                   EFGHIJKLMNOPQRSTUVW    
                                    FGHIJKLMNOPQRSTUV     
                                     GHIJKLMNOPQRSTU      
                                      HIJKLMNOPQRST       
                                       IJKLMNOPQRS        
                                        JKLMNOPQR         
                                         KLMNOPQ          
                                          LMNOP           
                                           MNO            
                                            N             

A -> A

AB -> AB

Pamiętaj, że to , więc wygrywa kod o najmniejszej liczbie bajtów.

Oliver Ni
źródło
Czy wyjściem może być lista ciągów zamiast drukowania ciągów?
Greg Martin
@GregMartin Tak.
Oliver Ni
1
Czy musimy mieć wiodące spacje na każdej linii?
ETHprodukcje
@ETHproductions Tak.
Oliver Ni
9
@Oliver To ważna informacja, którą powinieneś zamieścić w tekście
Luis Mendo,

Odpowiedzi:

11

V , 10 bajtów

ò^llYpr $x

Wypróbuj online!

Wyjaśnienie:

ò^ll         " While there are at least two non-whitespace characters on the current line
    Y        " Yank this line
     p       " Paste it below
      r      " Replace the first character with a space
        $    " Move to the end of the line
         x   " Delete a character
James
źródło
6

Python, 45 bajtów

f=lambda s,p='\n ':s and s+p+f(s[1:-1],p+' ')

Rekurencyjnie wyprowadza ciąg, plus znak nowej linii oraz spacje wiodące dla następnego wiersza, a także wynik rekurencyjny dla skróconego ciągu z dodatkową spacją w prefiksie.

Jeśli dozwolony byłby nowy wiersz, moglibyśmy zapisać bajt:

f=lambda s,p='\n':s and p+s+f(s[1:-1],p+' ')

Porównaj z programem (49 bajtów w Python 2):

s=input();p=''
while s:print p+s;s=s[1:-1];p+=' '
xnor
źródło
6

ES6 (JavaScript), 47, 48, 43 bajty

EDYCJA: Zastąpiony operator trójskładnikowy przez &&, poprzedzony ciąg dopełniający znakiem nowej linii. Dzięki @Neil za doskonałą poradę!

EDYCJA: zawarła nazwę funkcji dla rekurencyjnego wywołania, usunęła jeden bajt używając dosłownego nowego wiersza

Grał w golfa

R=(s,p=`
 `)=>s&&s+p+R(s.slice(1,-1),p+' ')

Test

R=(s,p=`
 `)=>s&&s+p+R(s.slice(1,-1),p+' ')

console.log(R("ABCDEFGHIJKLMNOPQRSTUVWXYZ"))

ABCDEFGHIJKLMNOPQRSTUVWXYZ
 BCDEFGHIJKLMNOPQRSTUVWXY
  CDEFGHIJKLMNOPQRSTUVWX
   DEFGHIJKLMNOPQRSTUVW
    EFGHIJKLMNOPQRSTUV
     FGHIJKLMNOPQRSTU
      GHIJKLMNOPQRST
       HIJKLMNOPQRS
        IJKLMNOPQR
         JKLMNOPQ
          KLMNOP
           LMNO
            MN

console.log(R("ABCDEFGHIJKLMNOPQRSTUVWXYZ!"))

ABCDEFGHIJKLMNOPQRSTUVWXYZ!
 BCDEFGHIJKLMNOPQRSTUVWXYZ
  CDEFGHIJKLMNOPQRSTUVWXY
   DEFGHIJKLMNOPQRSTUVWX
    EFGHIJKLMNOPQRSTUVW
     FGHIJKLMNOPQRSTUV
      GHIJKLMNOPQRSTU
       HIJKLMNOPQRST
        IJKLMNOPQRS
         JKLMNOPQR
          KLMNOPQ
           LMNOP
            MNO
             N
zepelin
źródło
1
Zauważam, że @xnor zaczyna się od znaku pnowej linii i spacji; może to też może ci pomóc.
Neil,
1
Aha, możesz też użyć s&&zamiast s?...:''.
Neil,
4

Python 2, 50 bajtów

def f(i,j=0):
 print' '*j+i
 if i:f(i[1:-1],j+1)

Prosta funkcja rekurencyjna, która skraca ciąg znaków, aż zniknie.

Wywołaj jako f („ciąg”)

Wynik

string
 trin
  ri
ElPedro
źródło
4

Perl, 31 bajtów

30 bajtów kodu + -pflaga.

s/( *)\S(.+).$/$& 
 $1$2/&&redo

Aby uruchomić:

perl -pE 's/( *)\S(.+).$/$&
 $1$2/&&redo' <<< "abcdef"

Objaśnienia : \Si .$odpowiadają pierwszej i ostatniej postaci, (.+)środkowej i ( *)końcowym spacjom, które są dodawane za każdym razem, gdy usuwamy jedną postać od początku. Zatem wyrażenie regularne usuwa jedną postać od początku, jedną od końca i za każdym razem dodaje jedną spację wiodącą.

Dada
źródło
4

Brainfuck , 67 bajtów

>>,[.>,]<[>++++++++++.<[-]<[<]>[-]++++++++[-<++++>]<[<]>[.>]>[.>]<]

To powinno działać na wszystkie smaki pieprzenia mózgu.

Wypróbuj online!

Nieskluczony kod:

# Print and read input_string into memory
>>,[.>,]<
while input_string is not empty [
    # Print newline
    >+++++ +++++.<
    # Remove last character
    [-]
    # GOTO start of input_string
    <[<]>
    # Remove first character
    [-]
    # Add space to space_buffer
    +++++ +++[-<++++>]
    # GOTO start of space_buffer
    <[<]>
    # Print space_buffer
    [.>]
    # Print input_string
    >[.>]
<]

Wciąż powinno być tu trochę bajtów; Dopiero niedawno zacząłem używać pieprzenia mózgu, więc mój ruch wskaźnika jest prawdopodobnie bardzo nieefektywny.

Aedan Smith
źródło
2

MATL , 9 bajtów

tg!*YRPRc

Tworzy to końcowe spacje i znaki nowej linii.

Wypróbuj online!

Wyjaśnienie

t      % Input string implicitly. Duplicate
g!     % Convert to logical and transpose: gives a column vector of ones
*      % Multiply with broadcast. This gives a square matrix with the string's
       % ASCII codes on each row
YR     % Lower triangular part: make elements above the diagonal 0
P      % Flip vertically
R      % Upper triangular part: make elements below the diagonal 0
c      % Convert to char. Implicitly display, with char 0 shown as space
Luis Mendo
źródło
2

Partia, 92 bajty

@set/ps=
@set t=
:g
@echo %t%%s%
@set t= %t%
@set s=%s:~1,-1%
@if not "%s%"=="" goto g

Pobiera dane wejściowe na STDIN.

Neil
źródło
2

C, 73 bajty

f(char*s){char*b=s,*e=s+strlen(s)-1;while(e-b>-1)puts(s),*b++=32,*e--=0;}

Nie golfowany:

f(char*s) {
  char *b=s,
       *e=s+strlen(s)-1;
  while (e-b>-1)
    puts(s),
    *b++=32,
    *e--=0;
}

Stosowanie:

main(){
  char a[] = "abcde";
  f(a);
}
Karl Napf
źródło
2

05AB1E , 8 bajtów

Kod:

ÐvNú,¦¨D

Wyjaśnienie:

Ð          # Triplicate the input
 v         # Length times do...
  Nú,      # Prepend N spaces and print with a newline
     ¦¨    # Remove the first and the last character
       D   # Duplicate that string

Wykorzystuje kodowanie CP-1252 . Wypróbuj online!

Adnan
źródło
2

Haskell, 47 43 bajtów

f s@(a:b:c)=s:map(' ':)(f.init$b:c)
f s=[s]

Wypróbuj na Ideone . Dane wyjściowe to lista ciągów dozwolonych w komentarzach do wyzwania. Aby wydrukować, uruchom (putStr.unlines.f)zamiast zamiastf .

Edycja: Zapisano 4 bajty po zauważeniu, że końcowe białe znaki są dozwolone.

Prelude> (putStr.unlines.f)"codegolf"
codegolf
 odegol
  dego
   eg
               --(trailing whitespace)
Laikoni
źródło
2

Perl 6 , 42 bajtów

for get,{S/\w(.*)./ $0/}.../\s..?$/ {.put}

Rozszerzony:

for

  # generate the sequence
  get,       # get a line from the input

  {          # bare block lambda with implicit parameter 「$_」
             # used to produce the rest of the sequence

    S/       # replace
      \w     # a word character ( to be removed )
      (      # set 「$0」
        .*   # any number of any characters
      )
      .      # any character ( to be removed )
    / $0/    # append a space

  }

  ...        # repeat that until

  /          # match
    \s       # whitespace
    .        # any character
    .?       # optional any character
    $        # end of string
  /

{
  .put       # print $_ with trailing newline
}
Brad Gilbert b2gills
źródło
1

GNU sed 24 bajty

Obejmuje +2 za -rn

:
p
s/[^ ](.+)./ \1/
t

Drukuje, zastępuje pierwszy znak spacji spacją i usuwa ostatni znak, dopóki nic się nie zmieni.

Riley
źródło
0

C ++ 14, 117 bajtów

auto f(auto s){decltype(s)r;auto b=s.begin();auto e=s.rbegin();while(e.base()-b>0)r+=s+"\n",*b++=32,*e++=0;return r;}

Zakłada, że ​​wejście sto a std::stringi zwraca animowany tekst.

Nie golfowany:

auto f(auto s){
  decltype(s)r;
  auto b=s.begin();
  auto e=s.rbegin();
  while(e.base()-b>0){
    r+=s+"\n";
    *b++=32;
    *e++=0;
  }
  return r;
}

Stosowanie:

main(){
  std::string a{"abcdef"};
  std::cout << f(a);
  std::string b{"abcde"};
  std::cout << f(b);
}
Karl Napf
źródło
0

Vim - 14 naciśnięć klawiszy

qqYp^r $x@qq@q


Wyjaśnienie:

qq  -- record a macro named 'q'
Y   -- Copy current line
p   -- Paste it
^r  -- Replace the first non-space character on the new line with a space
$x  -- Delete the last character on the line
@q  -- Recursively call the 'q' macro
q   -- Stop recording the 'q' macro
@q  -- Run the 'q' macro

Vim automatycznie zabija makro, gdy brakuje nam postaci

Gajówka
źródło
0

Kłapnięcie! - 16 bloków

Kłapnięcie!

Wyjście jest samocentrujące. „Czekanie” dotyczy ludzi.

wyldstallyns
źródło
0

PHP, 91 bajtów

<?for(;$i<.5*$l=strlen($s=$_GET[s]);$i++)echo str_pad(substr($s,$i,$l-$i*2),$l," ",2)."\n";

Sposób użycia: zapisz w pliku i zadzwoń z przeglądarki:

http://localhost/codegolf/string-middle.php?s=ABCDEFGHIJKLMNOPQRSTUVWXYZ

Raw output:
ABCDEFGHIJKLMNOPQRSTUVWXYZ
 BCDEFGHIJKLMNOPQRSTUVWXY 
  CDEFGHIJKLMNOPQRSTUVWX  
   DEFGHIJKLMNOPQRSTUVW   
    EFGHIJKLMNOPQRSTUV    
     FGHIJKLMNOPQRSTU     
      GHIJKLMNOPQRST      
       HIJKLMNOPQRS       
        IJKLMNOPQR        
         JKLMNOPQ         
          KLMNOP          
           LMNO           
            MN            


http://localhost/codegolf/string-middle.php?s=1ABCDEFGHIJKLMNOPQRSTUVWXYZ

Raw output:
1ABCDEFGHIJKLMNOPQRSTUVWXYZ
 ABCDEFGHIJKLMNOPQRSTUVWXY 
  BCDEFGHIJKLMNOPQRSTUVWX  
   CDEFGHIJKLMNOPQRSTUVW   
    DEFGHIJKLMNOPQRSTUV    
     EFGHIJKLMNOPQRSTU     
      FGHIJKLMNOPQRST      
       GHIJKLMNOPQRS       
        HIJKLMNOPQR        
         IJKLMNOPQ         
          JKLMNOP          
           KLMNO           
            LMN            
             M             
Mario
źródło
0

Mathematica, 71 bajtów

Table[#~StringTake~{i,-i},{i,Ceiling[StringLength@#/2]}]~Column~Center&

animacja znalezienia środka

ngenisis
źródło