Анимация, находящая середину

10

Учитывая непустую строку, продолжайте удалять первый и последний символы, пока не получите один или два символа.

Например, если строка была abcde, ваша программа должна напечатать:

abcde
 bcd
  c

Однако, если это так abcdef, он должен останавливаться на двух символах:

abcdef
 bcde
  cd

Конечные символы новой строки и конечные пробелы в конце каждой строки являются необязательными. Вы можете иметь столько, сколько хотите, или ни одного.

Контрольные примеры

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

Помните, что это , поэтому выигрывает код с наименьшим количеством байтов.

Оливер Ни
источник
Может ли вывод быть списком строк вместо печати строк?
Грег Мартин
@GregMartin Да.
Оливер Ни
1
Нужно ли иметь пробелы в каждой строке?
ETHproductions
@ETHproductions Да.
Оливер Ни
9
@ Оливер Это важная информация, вы должны включить ее в текст
Луис Мендо

Ответы:

11

V , 10 байт

ò^llYpr $x

Попробуйте онлайн!

Объяснение:

ò^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
Джеймс
источник
6

Python, 45 байт

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

Рекурсивно выводит строку, плюс новую строку, плюс начальные пробелы для следующей строки, а также рекурсивный результат для укороченной строки с дополнительным пробелом в префиксе.

Если разрешен начальный символ новой строки, мы можем сохранить байт:

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

Сравните с программой (49 байт в Python 2):

s=input();p=''
while s:print p+s;s=s[1:-1];p+=' '
XNOR
источник
6

ES6 (Javascript), 47, 4843 байта

РЕДАКТИРОВАТЬ: Заменить троичный оператор с &&, префикс строки дополнения с новой строки. Спасибо @Neil за отличный совет!

РЕДАКТИРОВАТЬ: включил имя функции для рекурсивного вызова, обрезать один байт с помощью буквального перевода строки

Golfed

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

Тестовое задание

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
дирижабль
источник
1
Я замечаю, что @xnor начинается с pравенства строки и пробела; Может быть, это может помочь вам тоже.
Нил
1
Ох, и вы также можете использовать s&&вместо s?...:''.
Нил
4

Python 2, 50 байт

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

Простая рекурсивная функция, которая сокращает строку до тех пор, пока она не исчезнет.

Вызов как f ('строка')

Вывод

string
 trin
  ri
ElPedro
источник
4

Perl, 31 байт

30 байтов кода + -pфлаг.

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

Чтобы запустить это:

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

Пояснения : \Sи .$соответствуют первому и последнему символу, (.+)середине и ( *)завершающим пробелам, которые добавляются каждый раз, когда мы удаляем один символ из начала. Таким образом, регулярное выражение удаляет один символ с начала, один с конца, и каждый раз добавляет один пробел.

папа
источник
4

Brainfuck , 67 байт

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

Это должно работать на все вкусы.

Попробуйте онлайн!

Код Ungolfed:

# 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
    >[.>]
<]

Здесь все еще должно быть несколько байтов для отсечки; Я только недавно начал использовать brainfuck, поэтому мое движение указателя, вероятно, очень неэффективно.

Эдан смит
источник
2

MATL , 9 байт

tg!*YRPRc

Это создает конечные пробелы и переводы строки.

Попробуйте онлайн!

объяснение

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
Луис Мендо
источник
2

Пакет, 92 байта

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

Принимает участие в STDIN.

Нил
источник
2

C 73 байта

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

Ungolfed:

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

Применение:

main(){
  char a[] = "abcde";
  f(a);
}
Карл Напф
источник
2

05AB1E , 8 байтов

Код:

ÐvNú,¦¨D

Объяснение:

Ð          # 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

Использует кодировку CP-1252 . Попробуйте онлайн!

Аднан
источник
2

Haskell, 47 43 байта

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

Попробуйте это на Ideone . Вывод - это список строк, которые были разрешены в комментариях к заданию. Чтобы распечатать, запустите (putStr.unlines.f)вместо просто f.

Редактировать: Сохранено 4 байта после того, как замечено, что конечный пробел разрешен.

Prelude> (putStr.unlines.f)"codegolf"
codegolf
 odegol
  dego
   eg
               --(trailing whitespace)
Laikoni
источник
2

Perl 6 , 42 байта

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

Expanded:

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
}
Брэд Гилберт b2gills
источник
1

GNU sed 24 байта

Включает +2 для -rn

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

Печатает, заменяет первый непробельный символ пробелом и удаляет последний символ, пока ничего не изменится.

Райли
источник
0

C ++ 14, 117 байт

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

Предполагается, что ввод sявляется std::stringи возвращает анимированный текст.

Ungolfed:

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

Применение:

main(){
  std::string a{"abcdef"};
  std::cout << f(a);
  std::string b{"abcde"};
  std::cout << f(b);
}
Карл Напф
источник
0

Vim - 14 нажатий клавиш

qqYp^r $x@qq@q


Объяснение:

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 автоматически убивает макрос, когда у нас заканчиваются символы

судейская шапочка
источник
0

Щелчок! - 16 блоков

Щелчок!

Выход самоцентрирующийся. «Ожидание» для людей.

wyldstallyns
источник
0

PHP, 91 байт

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

Использование: сохранить в файл и вызвать из браузера:

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             
Марио
источник
0

Mathematica, 71 байт

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

одушевленные ознакомительный-середина

ngenisis
источник