Вибухнули суфікси


20

Враховуючи рядок ASCII, виведіть з нього вибухані суфікси. Наприклад, якщо рядок був abcde, існує 5 суфіксів, упорядкованих найдовше до найкоротшого:

abcde
bcde
cde
de
e

Кожен суфікс потім вибухає , тобто кожен символ копіюється стільки ж разів, скільки його одноіндексоване місце у цьому суфіксі. Наприклад, вибух суфіксів abcde,

abcde
12345
abbcccddddeeeee

bcde
1234
bccdddeeee

cde
123
cddeee

de
12
dee

e
1
e

Загалом, вибухові суфікси abcdeє

abbcccddddeeeee
bccdddeeee
cddeee
dee
e

Правила

  • Це тому найкоротший код виграє.
  • Вхід складається з символів для друку ASCII. (Це виключає нові рядки, але включає пробіли.)
  • Вихід матиме кожен рядок в окремому рядку.
  • У кожному рядку дозволено пробіли, а в кінці може бути додатковий новий рядок.

Випробування

''

'a'
a

'bc'
bcc
c

'xyz'
xyyzzz
yzz
z

'code-golf'
coodddeeee-----ggggggooooooollllllllfffffffff
oddeee----gggggoooooolllllllffffffff
dee---ggggooooollllllfffffff
e--gggoooolllllffffff
-ggooollllfffff
goolllffff
ollfff
lff
f

's p a c e'
s  ppp    aaaaa      ccccccc        eeeeeeeee
 pp   aaaa     cccccc       eeeeeeee
p  aaa    ccccc      eeeeeee
 aa   cccc     eeeeee
a  ccc    eeeee
 cc   eeee
c  eee
 ee
e



Що відбувається у «ccodegolf»?
RosLuP

Відповіді:


14

Желе , 5 байт

ṫJxJY

Спробуйте в Інтернеті! або перевірити всі тестові випадки .

Як це працює

ṫJxJY  Main link. Argument: s (string)

 J     Indices; yield I := [1, ..., len(s)].
ṫ      Tail; get the suffixes of s starting at indices [1, ..., len(s)].
   J   Indices; yield I again.
  x    Repeat. The atom 'x' vectorizes at depth 1 (1D arrays of numbers/characters)
       in its arguments. This way, each suffix t gets repeated I times, meaning
       that the first character of t is repeated once, the second twice, etc.
       If left and right argument have different lengths, the longer one is
       truncated, so I can safely be applied to all suffixes.
    Y  Join, separating by linefeeds.

8

J, 22 12 8 байт

Дякуємо за милі за економію 14 байт!

(#~#\)\.

Тепер це дійсно приємне рішення. Також досить лаконічно.

Це гачок, #~#\застосований до суфіксів ( \.) вводу. Гак, коли його викликають на вході y, розкладається таким чином:

(#~#\) y
y #~ #\ y

Ось кілька проміжних результатів:

   ]s =: 's p a c e'
s p a c e
   #\ s
1 2 3 4 5 6 7 8 9
   (quote) s
's p a c e'
   (quote;#)\ s
+-----------+-+
|'s'        |1|
+-----------+-+
|'s '       |2|
+-----------+-+
|'s p'      |3|
+-----------+-+
|'s p '     |4|
+-----------+-+
|'s p a'    |5|
+-----------+-+
|'s p a '   |6|
+-----------+-+
|'s p a c'  |7|
+-----------+-+
|'s p a c ' |8|
+-----------+-+
|'s p a c e'|9|
+-----------+-+
   1 2 3 # '123'
122333
   3 3 3 # '123'
111222333
   ]\. s
s p a c e
 p a c e
p a c e
 a c e
a c e
 c e
c e
 e
e
   quote\. s
's p a c e'
' p a c e'
'p a c e'
' a c e'
'a c e'
' c e'
'c e'
' e'
'e'
   (#~#\) s
s  ppp    aaaaa      ccccccc        eeeeeeeee
   (#~#\)\. s
s  ppp    aaaaa      ccccccc        eeeeeeeee
 pp   aaaa     cccccc       eeeeeeee
p  aaa    ccccc      eeeeeee
 aa   cccc     eeeeee
a  ccc    eeeee
 cc   eeee
c  eee
 ee
e

Тестові кейси

   f =: (#~#\)\.
   f
(#~ #\)\.
   f ''
   f 'a'
a
   f 'bc'
bcc
c
   f 'xyz'
xyyzzz
yzz
z
   f 'code-golf'
coodddeeee-----ggggggooooooollllllllfffffffff
oddeee----gggggoooooolllllllffffffff
dee---ggggooooollllllfffffff
e--gggoooolllllffffff
-ggooollllfffff
goolllffff
ollfff
lff
f
   f 's p a c e'
s  ppp    aaaaa      ccccccc        eeeeeeeee
 pp   aaaa     cccccc       eeeeeeee
p  aaa    ccccc      eeeeeee
 aa   cccc     eeeeee
a  ccc    eeeee
 cc   eeee
c  eee
 ee
e

   ]tc =: <;._1 '|' , '|a|bc|xyz|code-golf|s p a c e'
++-+--+---+---------+---------+
||a|bc|xyz|code-golf|s p a c e|
++-+--+---+---------+---------+
   ,. f &. > tc
+---------------------------------------------+
+---------------------------------------------+
|a                                            |
+---------------------------------------------+
|bcc                                          |
|c                                            |
+---------------------------------------------+
|xyyzzz                                       |
|yzz                                          |
|z                                            |
+---------------------------------------------+
|coodddeeee-----ggggggooooooollllllllfffffffff|
|oddeee----gggggoooooolllllllffffffff         |
|dee---ggggooooollllllfffffff                 |
|e--gggoooolllllffffff                        |
|-ggooollllfffff                              |
|goolllffff                                   |
|ollfff                                       |
|lff                                          |
|f                                            |
+---------------------------------------------+
|s  ppp    aaaaa      ccccccc        eeeeeeeee|
| pp   aaaa     cccccc       eeeeeeee         |
|p  aaa    ccccc      eeeeeee                 |
| aa   cccc     eeeeee                        |
|a  ccc    eeeee                              |
| cc   eeee                                   |
|c  eee                                       |
| ee                                          |
|e                                            |
+---------------------------------------------+

Класно, ще один спосіб зберегти кілька байтів - за допомогою прислівника з префіксом
милі

@miles, що ти маєш на увазі?
Conor O'Brien

Ви можете отримати довжину кожного префікса як коротший спосіб генерування цього діапазону
миль

@miles Ах, звичайно.
Conor O'Brien

7

Пітон, 61 байт

f=lambda s,i=0:s[i:]and-~i*s[i]+f(s,i+1)or s and'\n'+f(s[1:])

Альтернатива 63:

f=lambda s,b=1:s and f(s[:-1],0)+s[-1]*len(s)+b*('\n'+f(s[1:]))

6

Python 3, 91 68 65 байт

def f(s):f(s[1:print(''.join(i*c for i,c in enumerate(s[0]+s)))])

Припиняється помилкою після друку потрібного виводу. Перевірте це на Ideone .

Як це працює

Перш ніж f може називати себе рекурсивно, показники s[1:...]повинні бути обчислені.

Спочатку enumerate(s[0]+s)даються всі пари (i, c) символів c of s - з першим символом, що дублюється - та відповідними індексами i . Підготовка s[0]служить тут двом цілям.

  • Перший символ s повинен бути повторений один раз, але перший показник дорівнює 0 .

  • Після того, як всі символи будуть оброблені, s[0]підніме IndexError , що призведе до того , що f закінчиться помилкою, а не друкує нові рядки до досягнення межі рекурсії.

''.join(i*c for i,c in ...)будує плоский рядок кожного c повтореного i разів, що printповторюється STDOUT.

Нарешті, оскільки printповертає None і s[1:None]просто s[1:], рекурсивний виклик f(s[1:...])повторює вищезазначений процес для s без його першого символу.


6

Perl 6 , 38 байт

m:ex/.+$/.map:{put [~] .comb Zx 1..*}

37 байт + 1 для -nкомутатора командного рядка

Приклад:

$ perl6 -ne 'm:ex/.+$/.map:{put [~] .comb Zx 1..*}' <<< 'code-golf'
coodddeeee-----ggggggooooooollllllllfffffffff
oddeee----gggggoooooolllllllffffffff
dee---ggggooooollllllfffffff
e--gggoooolllllffffff
-ggooollllfffff
goolllffff
ollfff
lff
f

Розширено:

# -n command line switch takes each input line and places it in 「$_」

# You can think of it as surrounding the whole program with a for loop
# like this:
for lines() {

  # match
  m
  :exhaustive # every possible way
  / .+ $/     # at least one character, followed by the end of the string

  .map:

  {
    put           # print with newline
      [~]         # reduce using string concatenation ( don't add spaces between elements )
        .comb     # split into individual chars
        Z[x]      # zip using string repetition operator
        1 .. *    # 1,2,3,4 ... Inf
  }

}

5

Брахілог , 17 байт

@]Elyk:Erz:jac@w\

Спробуйте в Інтернеті!

Пояснення

@]E                 E is a suffix of the Input
   lyk              The list [0, ..., length(E) - 1]
      :Erz          The list [[0th char of E, 0], ..., [Last char of E, length(E) - 1]]
          :ja       For all elements of that list, concatenate the Ith char I times to itself
             c      Concatenate the list into a string
              @w    Write followed by a line break
                \   False: backtrack to another suffix of the Input



4

C #, 101 байт

f=s=>{var r="\n";for(int i=0;i<s.Length;)r+=new string(s[i],++i);return""==s?r:r+f(s.Substring(1));};

Рекурсивна анонімна функція, яка також друкує провідний новий рядок. Якщо провідний новий рядок не дозволений, 3 зайвих байта перетворять його у новий новий рядок:

f=s=>{var r="";for(int i=0;i<s.Length;)r+=new string(s[i],++i);return""==s?r:r+"\n"+f(s.Substring(1));};

Повна програма з методом unolfolf та тестовими кейсами:

using System;

namespace ExplodedSuffixes
{
    class Program
    {
        static void Main(string[] args)
        {
            Func<string, string> f = null;
            f = s =>
            {
                var r = "\n";
                for (int i = 0; i < s.Length; )
                    r += new string(s[i], ++i);
                return "" == s ? r : r + f(s.Substring(1));
            };

            // test cases:
            string x = "abcde";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "a";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "bc";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "xyz";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "code-golf";
            Console.WriteLine("\'" + x + "\'" + f(x));
            x = "s p a c e";
            Console.WriteLine("\'" + x + "\'" + f(x));
        }
    }
}

4

Haskell, 48 байт

e=map(concat.zipWith replicate[1..]).scanr(:)[] 

пов'язаний будь-яким із

ghc exploded_suffixes.hs -e 'e"abcde"'
ghc exploded_suffixes.hs -e 'mapM_ putStrLn.e=<<getLine' <<<code-golf
ghc exploded_suffixes.hs -e 'Control.Monad.forever$putStr.unlines.e=<<getLine'

Мені подобається точкова вільність. Ви повинні помістити свій 63-байтний код у свій власний блок, а потім показати виклик окремо.
xnor

Вам не потрібно putStr., ми приймаємо як функцію виведення. Вам потрібно import Data.Listхоч користуватися tails.
xnor

Ви можете замінити uncurry ... zipз zipWith: unlines.map(concat.zipWith replicate[1..]).tails.
німі

Так, справді! Скорочення zipWith replicateтакож трапилося для мене, коли я прокинувся. Шкода , що tailsне в Preludeя міг би витягти tailsз Data.Listнеявно без повного import і до сих пір не переростає в foldrеквіваленті. Що стосується чистоти без IOкотла, то я також залишаю mapM_ putStrLnприправу на смак читачів і не виконуватиме жодної unlines. Визначення блоку e=коштуватиме кількість байтів.
Роман Чиборра

Використання кваліфікованих імен без imports- це не стандартне Haskell, але особливість ghciвідбиття. Залежно від таких речей вважається окремою мовою, тому я пропоную змінити назву вашої відповіді на щось подібне Haskell (ghci). ( Див. Також цю мета-дискусію ).
німі

3

Perl, 36 + 1 ( -n) = 37 байт

/.+$(?{$.=say$&=~s%.%$&x$.++%rge})^/

Потрібно -nта -E(або -M5.010) запустити:

perl -nE '/.+$(?{$.=say$&=~s%.%$&x$.++%rge})^/' <<< "code-golf"

Зауважте, що він працює лише на одному екземплярі щоразу, коли ви запускаєте його (оскільки він використовує змінну, $.яка збільшується щоразу, коли читається рядок, тому він утримує 1лише перший раз, коли читається рядок). (Але тут немає жодних проблем, просто ^Dі знову запустіть!)



3

Java, 150 127 байт

Редагувати:

  • -23 байт вимкнено. Завдяки @Kevin Cruijssen

Знімок:

f->{String s[]=f.split(""),o="";int i=-1,j,l=s.length;for(;++i<l;)for(j=-2;++j<i;o+=s[i]);return l<1?"":o+"\n"+f.substring(1);}

Безголівки:

public static String explodeSuff(String suff){
  char [] s = suff.toCharArray();
  String out = "";
  if(s.length==0)return "";
  for(int i=-1;++i<s.length;){
    for(int j=-2;++j<i;){
      out+=s[i];
    }
  }
  return out+"\n"+suff.subString(1);
}

Привіт, ви можете трохи f->{String s[]=f.split(""),o="";int i=-1,j,l=s.length;for(;++i<l;)for(j=-2;++j<i;o+=s[i]);return l<1?o:o+"\n"+f.substring(1);}
пограти в

2

Ракетка 184 байти

(let p((l(string->list s))(ol'()))(cond[(null? l)(display(list->string(flatten ol)))]
[else(p(cdr l)(append ol(list #\newline)(for/list((i l)(n(length l)))(for/list((j(+ 1 n)))i))))]))

Безголівки:

(define(f s)
 (let loop((l(string->list s))
             (outl '()))
    (cond
      [(null? l)
       (display
        (list->string
         (flatten outl)))]
      [else
       (loop
        (rest l)
        (append outl
                (list #\newline)
                (for/list ((i l)
                           (n (length l)))
                  (for/list ((j (add1 n)))
                    i
                    ))))]  )))


(f "abcde")
(f "xyz")

Вихід:

abbcccddddeeeee
bccdddeeee
cddeee
dee
e

xyyzzz
yzz
z

2

JavaScript (ES6), 65 байт

f=s=>s?[s.replace(/./g,(c,i)=>c.repeat(i+1)),...f(s.slice(1))]:[]
<input oninput=o.textContent=f(this.value).join`\n`><pre id=o>

Попередні спроби:

67: s=>[...s].map((_,i)=>s.slice(i).replace(/./g,(c,i)=>c.repeat(i+1)))
84: s=>s.replace(/./g,`$&$'
    `).match(/.+/g).map(s=>s.replace(/./g,(c,i)=>c.repeat(i+1)))
89: f=(s,t=s.replace(/./g,(c,i)=>c.repeat(i+1)))=>t?[]:[t,...f(s,t.replace(/(.)(?=\1)/g,''))]

2

PHP, 103 байти (99 з короткими тегами)

<?php for($s=$argv[1];""!=$s[$i++];$o.="
")for($j=0;""!=$l=$s[$j+$i-1];)$o.=str_pad('',++$j,$l);echo$o;

Я впевнений, що це не найкоротша відповідь.


2

MATL , 12 байт

&+gYRYs"G@Y"

Мені подобається, коли лапки збираються!

Спробуйте в Інтернеті!

Пояснення

Це працює, будуючи матрицю, стовпці якої використовуються по черзі для декодування вхідної довжини. Як приклад, для введення 'abcde'матриця є

1 0 0 0 0
2 1 0 0 0
3 2 1 0 0
4 3 2 1 0
5 4 3 2 1

Код:

&+g    % Implicit input. NxN matrix of ones, where N is input size
YR     % Set entries above diagonal to zero
Ys     % Cumulative sum of each column. This gives the desired matrix 
"      % For each column
  G    %   Push input (for example 'abcde')
  @    %   Push current column (for example [0;0;1;2;3])
  Y"   %   Run-length decode (example output 'cddeee')
       % Implicit end
       % Implicit display

1

Python 3, 95 байт

def f(s):return'\n'.join(''.join(s[j:][i]*(i+1)for i in range(len(s)-j))for j in range(len(s)))

Це було напрочуд важче, ніж я очікував. Я переробив всю свою функцію, можливо, 4 рази.


1

Java 7 140 байт

void c(char[]a,int l,int j){if(l<1)return;c(a,--l,++j);for(int i=0,k;i<j;i++)for(k=0;k++<=i;)System.out.print(a[i+l]);System.out.println();}

Безумовно

 void c(char[]a,int l,int j)
{
if (l < 1) 
return ;
c(a , --l , ++j) ;
for(int i = 0 , k; i < j ; i++)
for(k = 0 ; k++ <= i ;)
System.out.print(a[i+l]);
System.out.println();
}

Наступний рядок надає мені дуже болю. Я не знаю, як я можу взяти участь у гольфі (тому що "\n"в друкованій заяві є дві петлі, щоб порушити умову ).
System.out.println();


Як щодо правильного методу, який не вимагає надсилання довжини масиву як аргумент? В даний час можна запустити виняток IndexOutOfBounds, випадково надіславши неправильне значення ...
adrianmp



1

R, 108 байт

Прочитайте введення зі stdin та друкує до stdout

s=scan(,"");n=nchar(s);for(i in 1:n)cat(do.call("rep",list(strsplit(s,"")[[1]][i:n],1:(n-i+1))),"\n",sep="")

Я вважав, що використання do.callтут було доречним. В основному він займає два входи: 1. ім'я функції у вигляді рядка ( repтут) і списку аргументів; 2. ітеративно застосовує виклики функції, використовуючи аргументи у списку.

Наприклад:

  • rep("c",3) виробляє вектор "c" "c" "c"
  • do.call("rep",list(c("a","b","c"),1:3)) виробляє вектор "a" "b" "b" "c" "c" "c"
  • що еквівалентно послідовним викликам rep("a",1), rep("b",2)іrep("c",3)

1

Vim, 43 байти

qqYlpx@qq@qqr0<C-H><C-V>{$:s/\v%V(.)\1*/&\1/g<CR>@rq@r

Перший макрос розділяє суфікси, другий макрос "вибухає" їх. Ймовірно, піддається перемозі. Простіри дратують.


1

С, 186 байт

#include <string.h>
#define S strlen
p(char* s){char *t=s;char u[999]="";for(int i=0;i<S(s);i++){for(int j=i+1;j>0;j--){sprintf(u+S(u),"%c",*t);}t++;}printf("%s\n",u);if(S(s)>1)p(s+1);}

Це, напевно, можна трохи скоротити, але я просто хотів спробувати. Це моя друга спроба в гольфі, тому дайте мені будь-які вказівки (* lol), які ви можете. Він приймає рядок як параметр і робить вибух звідти. u використовується як буфер, який зберігає вибухану рядок.

Безголівки:

#include <string.h>
#define S strlen 
p(char* s){
    char *t=s;
    char u[999]="";
    for(int i=0;i<S(s);i++){
        for(int j=i+1;j>0;j--){
            sprintf(u+S(u),"%c",*t);
        }
        t++;
    }
    printf("%s\n",u);
    if(S(s)>1)p(s+1);
}

1

Acc !! , 150 байт

Очікує введення на stdin, що закінчується символом табуляції.

N
Count c while _/128^c-9 {
_+N*128^(c+1)
}
Count i while _-9 {
Count j while _/128^j-9 {
Count k while j+1-k {
Write _/128^j%128
}
}
Write 10
_/128
}

Пояснення

Це насправді досить добре завдання для Acc !! , оскільки для цього потрібно лише прочитати рядок і повторити її за допомогою деяких вкладених циклів. Ми читаємо рядок в акумулятор, трактуючи його як послідовність базових 128 цифр, з першим символом на кінці низького порядку. Після Count cциклу відкриття значення акумулятора можна концептуалізувати так (використовуючи xyzв якості прикладу введення):

128^   3  2  1  0
     tab  z  y  x

(Фактичне значення акумулятора для цього прикладу 9*128^3 + 122*128^2 + 121*128 + 120= 20888824.)

Тоді ми можемо повторювати рядок шляхом ітерації над зростаючими потужностями 128. І ми можемо повторити суфікси, розділивши акумулятор на 128 після кожної ітерації, відрізаючи символ.

З відступом та коментарями:

# Initialize the accumulator with the first input character
N
# Loop until most recent input was a tab (ASCII 9)
Count c while _/128^c - 9 {
    # Input another character and add it at the left end (next higher power of 128)
    _ + N * 128^(c+1)
}

# Loop over each suffix, until only the tab is left
Count i while _ - 9 {
    # Loop over powers of 128 until the tab
    Count j while _/128^j - 9 {
        # Loop (j+1) times
        Count k while j + 1 - k {
            # Output the j'th character
            Write _ / 128^j % 128
        }
    }
    # Output a newline
    Write 10
    # Remove a character
    _/128
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.