Напишите программу для эластизации струн

33

Хороший глагол там, в названии.

Напишите программу, которая задает входную строку, «упростит» эту строку и выведет результат. Эластизация строки выполняется следующим образом:

Первый символ отображается один раз. Второй символ показан дважды. Третий символ показан трижды и так далее.

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

Вы можете ожидать получения только печатных символов ASCII. Исходя из следующей ссылки , эти символы имеют десятичные значения 32-126.

Примеры:

Why: Whhyyy

SKype: SKKyyyppppeeeee

LobbY: LoobbbbbbbYYYYY (Обратите внимание, что существует 7 b, поскольку первый b показан 3 раза, а второй b показан 4 раза, что составляет в общей сложности 7 b).

A and B: A aaannnnddddd BBBBBBB

Кратчайшие байты выигрывают :)

Марио Исхак
источник
2
Это, похоже, не согласуется с тем, что «поддержка пробелов не требуется, кроме символа пробела». Должен ли вывод быть таким же, как ввод? (Два однобуквенных слова?) Также обратите внимание, что у нас есть замечательное место под названием « Песочница», где вы можете ставить перед людьми задачи, чтобы они могли дать вам обратную связь перед их публикацией.
FryAmTheEggman
FryAmTheEggman ваше предположение верно. @TimmyD Я понимаю, где мне было неясно, у вас могут получиться строки, разделенные моими несколькими пробелами, как видно из примера, опубликованного FryAmTheEggman.
Марио Исхак
Я предполагаю, что самый короткий код выигрывает? ;)
Аднан
@ Adnan Да, хотя я не уверен, должен ли я отмечать ответ закороченной программой как принятый, поскольку некоторые языки сделаны для целей игры в гольф в отличие от других.
Марио Исхак
2
Связанный: 1 , 2
Sp3000

Ответы:

34

Желе , 3 байта

Код:

ĖP€

Explanation:

Ė     # Enumerate.
 P€   # Product of each.
      # Implicit joining of everything.

Uses the Jelly encoding. Try it online!.

Adnan
источник
16
Хорошее злоупотребление тем фактом, что Python *выполняет умножение строк. Это не совсем так, но это работает.
Деннис
1
@ Денис: что *? Во всем ответе такого нет.
Томас Веллер
10
@Thomas: Jelly написан на Python, а команда Jelly Pрассчитывает продукт за кулисами, используя *оператор Python . Этот пост злоупотребляет утечкой абстракции базового кода, фактически находящегося в Python, поэтому выполнение команды P(product) для строки работает, как и ожидалось.
mellamokb
16

J, 4 байта

#~#\

использование

   f =: #~#\
   f 'Why'
Whhyyy
   f 'SKype'
SKKyyyppppeeeee
   f 'LobbY'
LoobbbbbbbYYYYY
   f 'A and B'
A  aaannnnddddd      BBBBBBB

объяснение

#~#\  Input: s
  #\  Computes the length of each prefix of s
      This forms the range [1, 2, ..., len(s)]
#~    For each value in the range, copy the character at the
      corresponding index that many times
      Return the created string
миль
источник
12

Brainfuck, 15 байтов

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

Довольно простая реализация, смещающая область памяти на 1 для каждого входного символа. Требуется интерпретатор, который дает 0 для EOF и 32-битные ячейки с произвольной точностью для входов длиннее 255 символов.

Попробуйте онлайн! (Примечание: TIO использует 8-битные ячейки)

Sp3000
источник
1
Кроме того, я думаю, что это не работает для строк длиннее 255 символов.
Исмаэль Мигель
@IsmaelMiguel That would depend on whether the interpreter in question has arbitrary precision integers or not (but indeed, for most implementations, it would cap at 255)
Sp3000
Соглашение должно использовать 8 битов. Который является 1 символом. Но некоторые действительно могут реализовать с 32-разрядными числами. Поскольку вы указываете, что вам нужно, чтобы значение EOF было 0 (это поведение, специфичное для компилятора / интерпретатора), следует отметить, что для строк длиннее 255 символов вам нужен компилятор / интерпретатор с 32-битными ячейками. Я просто думаю, что это должно быть добавлено к ответу, поскольку это также поведение, специфичное для компилятора / интерпретатора.
Исмаэль Мигель
1
@IsmaelMiguel Конечно, отметил.
Sp3000
8

Джава, 158 121 байт

Спасло колоссальные 37 байтов благодаря Кевину Круйссену !

interface a{static void main(String[]A){int b=0,B;for(char c:A[0].toCharArray())for(B=b+++2;--B>0;)System.out.print(c);}}

As a bonus, this program can handle all Unicode characters in the existence, including the control characters located at the very end of Basic Multilingual Plane.

dorukayhan wants Monica back
источник
3
Huh, this is very short for a Java code.
Ave
1
You can shorten it by 1 byte by replacing for(int C=c+1;C>0;C--) with for(int C=c+2;--C>0;)
Kevin Cruijssen
2
Or even shorter (121 bytes): interface a{static void main(String[]A){int x=0,i;for(char c:A[0].toCharArray())for(i=x+++2;--i>0;)System.out.print(c);}}
Kevin Cruijssen
Well, just make it a lambda or a method
Leaky Nun
2
Wow, using an interface for the default public methods. That's smart.
Justin
7

Perl, 16 bytes

s/./$&x$+[0]/ge

+1 byte for the -p flag.

s/./        /    find every character
             g   globally
              e  and replace with the eval'd result of
    $&           the matched string
      x          repeated
       $+[0]     by the index of the character after the match
Doorknob
источник
7

Haskell, 29 bytes

concat.zipWith replicate[1..]

Usage example: concat.zipWith replicate[1..] $ "SKype" -> "SKKyyyppppeeeee".

replicate n c makes n copies of c and concat makes a single list out of all the sublists.

nimi
источник
id=<< is a nice touch. :)
sudee
I just wanted to try it, but assigning f = id=<<zipWith replicate[1..] (in a file) did result in an ugly error, can you tell what I'm doing wrong?
flawr
Shouldn't it be possible to assign this (unnamed, right?) function to a name, such that we can use it as a function? I mean if it is a function, then (id=<<zipWith replicate[1..] ) "SKype" should still work? Otherwise I would consider it as a snippet. The full program you provided does have "SKype" hardcoded.
flawr
I'd say if you cannot use it like any other function, it is not a function. E.g. :t does not regard id=<<zipWith replicate[1..] as a function (it just throws an error) however (id=<<).zipWith replicate[1..] is considered as a function. I'd say the first one is just a snipped, that just works if you hardcode the input, but the second one that you just postet is a function (and :t agrees), would you agree on that?
flawr
Ok, great! If you disagree with my "definition", I think we should start a meta post for clearing this up. In the mean time I'm trying to find some other haskellians for their opinion on this, as this is just my view.
flawr
7

CJam, 9 8 7 bytes

Thanks to jimmy23013 for saving 1 byte.

Sl+eee~

Test it here.

Explanation

Using the LobbY example:

                                      Stack:
S    e# Push space.                   [" "]
l    e# Read input.                   [" " "LobbY"]
+    e# Append.                       [" LobbY"]
ee   e# Enumerate.                    [[[0 ' ] [1 'L] [2 'o] [3 'b] [4 'b] [5 'Y]]]
e~   e# Run-length decode.            ["LoobbbbbbbYYYYY"]
Martin Ender
источник
5

Javascript ES6, 39 bytes

x=>x.replace(/./g,(y,i)=>y+y.repeat(i))

Same length, but more fun:

x=>x.replace(i=/./g,y=>y.repeat(i=-~i))

Snippet demo:

f= x=>x.replace(/./g,(y,i)=>y+y.repeat(i))
run.onclick=_=>output.textContent=f(input.value)
<input id="input" value="SKype">
<button id="run">Go</button>
<pre id="output"></pre>

nderscore
источник
Small error, the program does not support spaces, which is required as a submission (check the OP).
Mario Ishac
@MarDev I changed the snippet to use <pre> instead of <div>, that should help.
Neil
1
@Neil Ah, so the result was correctly computed, but the output was rendered incorrectly by the HTML. Forgot that <div> does that.
Mario Ishac
..."and output the result"
spender
1
@spender returning is a valid form of output for functions
cat
4

APL (8)

{⍵/⍨⍳⍴⍵}

I.e.:

      {⍵/⍨⍳⍴⍵} ¨  'Why' 'SKype' 'LobbY'
┌──────┬───────────────┬───────────────┐
│Whhyyy│SKKyyyppppeeeee│LoobbbbbbbYYYYY│
└──────┴───────────────┴───────────────┘

Explanation:

  • ⍴⍵: length of given vector
  • : numbers 1..N
  • ⍵/⍨: replicate each element in N times.
marinus
источник
4

MATLAB, 45 bytes

g=@(m)sort(m(m>0));@(s)s(g(hankel(1:nnz(s))))

Explanation: The key is hankel, which produces a Hankel matrix of a given vector. From this matrix, we can extract a vector of indices, which defines which character of the string is at which position in the output. E.g. hankel(1:4) produces following matrix:

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

From this matrix we can extrac the vector 1,2,2,3,3,3,4,4,4,4,4. This vector allows us to output the first character of the string once, the second one twice e.t.c.

flawr
источник
4

NARS2000, 6 chars = 12 bytes

⍳∘⍴/⊙⊢

⍳∘⍴ enumeration of the argument... (indices of its length)
/⊙ replicates the elements of...
the unmodified argument

Adám
источник
link to interpreter?
cat
@cat See edit (in header).
Adám
@cat What was your edit?
Adám
Identical to yours down to the character, because I googled it myself and my edit took 10 minutes to submit
cat
Also, in which codepage is this 6 bytes?
cat
3

PowerShell v2+, 36 bytes

-join([char[]]$args[0]|%{"$_"*++$i})

Takes input $args[0], explicitly casts it as a char array, sends that into a loop |%{...}. Each iteration we take the current letter/character "$_" and use the * overloaded operator to concatenate the string pre-incremented $i times. The result of each loop iteration is encapsulated in parens to form an array and then -joined together to form a string. That string is left on the pipeline and output is implicit.

Examples

PS C:\Tools\Scripts\golfing> .\elasticize-a-word.ps1 Why
Whhyyy

PS C:\Tools\Scripts\golfing> .\elasticize-a-word.ps1 SKype
SKKyyyppppeeeee

PS C:\Tools\Scripts\golfing> .\elasticize-a-word.ps1 LobbY
LoobbbbbbbYYYYY

PS C:\Tools\Scripts\golfing> .\elasticize-a-word.ps1 'a b'
a  bbb
AdmBorkBork
источник
3

Brachylog, 13 bytes

:ImC,0:Ie,Cw\

This prints the result to STDOUT.

Explanation

This is a good example of exploiting backtracking to loop.

:ImC            C is the Ith character of the Input
    ,
     0:Ie       Unify an implicit variable with an integer between 0 and I
         ,
          Cw    Write C to STDOUT
            \   False, trigger backtracking. It will go back to 0:Ie and unify the implicit
                variable with another integer, until all integers were used. After that, it
                will backtrack to :ImC and unify I and C with the next character.
Fatalize
источник
3

MATLAB, 23 bytes

@(x)repelem(x,1:nnz(x))

Creates an anonymous function ans that can be called using ans('stringtoelacticize')

Suever
источник
What version are you using? Cannot find repelem in my (relatively old) version =(
flawr
1
@flawr repelem was introduced in R2015a
Luis Mendo
3

K/Kona, 14 bytes

{,/(1+!#x)#'x}

Usage:

k){,/(1+!#x)#'x}"A and B"
"A  aaannnnddddd      BBBBBBB"
Simon Major
источник
3

Perl 6,  22 20  19 bytes

{S:g/(.)/{$0 x$/.to}/}
{S:g[(.)]=$0 x$/.to}
{[~] .comb Zx 1..*}

Explanation:

{          # implicit parameter $_
  [~]      # string concatenate the following list
    .comb  # the NFG characters from $_
    Z[x]   # zip combined using the string repetition operator
    1 .. * # 1 to infinity
}
Brad Gilbert b2gills
источник
3

VBA, 75 bytes

Function e(s):For a=1 To Len(s):e=e &String(a,Mid(s,a,1)):Next:End Function

Call as e.g. a user function in a spreadsheet.

=e(A1)

┌─────────┬───────────────┐
│   SKype │SKKyyyppppeeeee│
└─────────┴───────────────┘

It truncates if you feed it its own output a few times :-).

Joffan
источник
2
Welcome to the site! =)
DJMcMayhem
3

PHP, 68 bytes

<?php foreach(str_split($argv[1])as$i=>$a)echo str_repeat($a,$i+1);
Simon
источник
Hi, and welcome to PPCG! Nice first post!
Rɪᴋᴇʀ
You can get it down to 47 bytes: for(;$a=$argv[1][$i++];)echo str_repeat($a,$i);.
insertusernamehere
3

Javascript ES6, 42 41 bytes

s=>[,...s].map((e,i)=>e.repeat(i)).join``

Example runs:

f=s=>[,...s].map((e,i)=>e.repeat(i)).join``

f("Why")   => "Whhyyy"
f("SKype") => "SKKyyyppppeeeee"
f("LobbY") => "LoobbbbbbbYYYYY"
Dendrobium
источник
Same length: s=>[...s].reduce((a,b,i)=>a+b.repeat(i+1))
Bassdrop Cumberwubwubwub
2
-1 byte: s=>[,...s].map((e,i)=>e.repeat(i)).join``
nderscore
@nderscore Aha, thats clever, thanks!
Dendrobium
3

Retina, 22 bytes

Byte count assumes ISO 8859-1 encoding.

.
$&$.`$*·
+`(.)·
$1$1

Try it online!

Basically, we insert the right amount of · as placeholders between the characters (since these extended ASCII characters can't appear in the input), then fill them up with the adjacent character in the second stage.

Martin Ender
источник
3

R, 83 50 bytes

-23 Thanks to Giuseppe, though he used essentially an entire new method altogether

function(s)intToUtf8(rep(utf8ToInt(s),1:nchar(s)))

My original post:

function(s){r="";for(i in 1:nchar(s))r=paste0(r,strrep(el(strsplit(s,""))[i],i));r}

Try it online!

I feel like there's definitely a better way to do this, but with my new knowledge of a few functions in R, this is my approach.

Sumner18
источник
1
Not a golfing tip, but your code link output was messed up. Here
Robert S.
Ah, I see. I'm new to TIO, so I didn't quite understand the header/footer portions. Thank You!
Sumner18
1
Very nice! However, using rep and the argument collapse="" to paste is shorter, and utf8ToInt is shorter still! TIO
Giuseppe
2

Actually, 7 bytes

' +ñ♂πΣ

Try it online!

Explanation:

' +ñ♂πΣ
' +      prepend a space
   ñ     enumerate ("abc" -> [[0, 'a'], [1, 'b'], [2, 'c']])
    ♂π   map: for each character, repeat it n times
      Σ  concatenate
Mego
источник
2

Pyth - 5 bytes

1 byte saved thanks to @FryAmTheEggman.

s*VSl

Test Suite.

Maltysen
источник
@FryAmTheEggman ah, nice one.
Maltysen
2

Python 3, 48 47 bytes

Thanks to mego for saving a byte with the -~i trick.

lambda s:''.join(c*-~i for i,c in enumerate(s))

This is mostly self-explanatory. One thing for those not versed in Python: The * operator is overloaded to act like Perl's x operator, repeating its string argument the number of times specified by its numeric argument. E.g. 'foo' * 3 == 'foofoofoo'

bkul
источник
c*-~i is shorter than c*(i+1).
Mego
2

C#, 81 Bytes

void f(string s){for(int i=0;i<s.Length;i++)Console.Write(new String(s[i],i+1));}
ScifiDeath
источник
you can save 1 byte by changing to a foreach loop, e.g. foreach(var a in s)Console.Write(new C(a,1*i++));
Abbath
but if its a foreach we don't have the i variable so you'd need to declare it.
ScifiDeath
It seems you're missing a using System or a System. in front of the Console.
Martin Ender
@ScifiDeath That's true - but the end result is still one byte shorter. Sorry for omitting it and causing confusion int i=1;
Abbath
Also one byte shorter using Linq: void f(string s){s.Select((c,i)=>{Console.Write(new string(c,i+1));return c;});}. The need for a (unused) return value is ugly though. Edit: just found similar snippets in other answers further back.
linac
2

MATL, 5 bytes

tn:Y"

Try it Online

Explanation

    % Implictly grab input as a string
tn  % Duplicate and compute the length (N)
:   % Create an array from [1...N]
Y"  % Perform run-length decoding to elacticize the string
    % Implicitly display the result
Suever
источник
2

Python, 40 bytes

f=lambda s,i=1:s and s[0]*i+f(s[1:],i+1)
xnor
источник
2

Julia, 34 bytes

!s=s>""?!s[1:(e=end)-1]*s[e:e]^e:s

Try it online!

Dennis
источник
Your solution was good. But I managed to beat it.
Glen O
I saw. I had c%n="$c"^n;~s=join([s[r=1:end]...].%r), but that's actually longer. split was the missing piece of the puzzle.
Dennis
2

TSQL, 97 bytes

Golfed:

DECLARE @x varchar(max)='Lobby'
DECLARE @ int=LEN(@x)WHILE @>0SELECT
@x=STUFF(@x,@,1,REPLICATE(SUBSTRING(@x,@,1),@)),@-=1PRINT @x

Ungolfed:

DECLARE @x varchar(max)='Lobby'

DECLARE @ int=LEN(@x)
WHILE @>0
  SELECT 
    @x=STUFF(@x,@,1,REPLICATE(SUBSTRING(@x,@,1),@)),
    @-=1

PRINT @x

Try it online

t-clausen.dk
источник