Pedaço + Enumere uma lista de dígitos

11

Eu tenho uma lista de dígitos decimais:

4, 4, 4, 7, 7, 9, 9, 9, 9, 2, 2, 2, 4, 4

A lista de dígitos decimais é conhecida como itens. Podemos formar "pedaços" desses itens agrupando números idênticos e adjacentes. Desejo atribuir a cada bloco um número único, iniciando em 1 e aumentando em 1 na ordem em que os blocos aparecem na lista original. Portanto, a saída para o exemplo fornecido ficaria assim:

1, 1, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 5

Formato de entrada

Uma lista de dígitos. (0-9) Você pode usar os idiomas internos para ler esta lista da maneira que desejar. Codificação: ASCII

Formato de saída

Uma série de números decimais, separados por um delimitador. Seu programa sempre deve usar o mesmo delimitador. O delimitador deve ter mais de 0 bits. Codificação: ASCII

Aplicam-se brechas padrão.

noɥʇʎԀʎzɐɹƆ
fonte
8
Alguma razão específica para o formato estrito de entrada e saída?
String não relacionada
2
@UnrelatedString Hmm, eu os afrouxo.
noɥʇʎԀʎzɐɹƆ
8
O IO ainda é bastante rigoroso. Você não pode simplesmente dizer "entrada e saída é como uma lista" e deixar que os padrões do site cuidem disso para você?
Jo rei
2
Podemos assumir que a lista não está vazia?
Jo rei
1
Uma lista por definição já possui delimitadores. É por isso que é uma lista. Eu também não entendo o que você quer dizer com You may use your language built-ins to read this list however you want.. Isso significa que precisamos incluir uma string para listar o conversor em nossa submissão? E são nós permissão para saída como uma lista?
Jo rei

Respostas:

7

Python 3.8 (pré-lançamento) , 41 bytes

lambda l,n=0:[n:=n+(l!=(l:=x))for x in l]

Experimente online!

Elogie a morsa mágica :=das expressões de atribuição.


Python 2 , 42 bytes

n=0
for x in input():n+=x!=id;id=x;print n

Experimente online!

xnor
fonte
Hmm, quanto tempo isso levaria em Pyth?
noɥʇʎԀʎzɐɹƆ 14/08/19
Ah, evitei idporque tem 2 bytes de comprimento ...
Erik the Outgolfer
Oof boa idéia deid
U10-Forward
@ noɥʇʎԀʎzɐɹƆ 8 bytes para uma tradução simples: Experimente online!
Isaacg 14/12/19
6

Python 2 , 44 bytes

l=input()
n=0
for i in l:n+=i!=l;l=i;print n

Experimente online!

Erik, o Outgolfer
fonte
3

Geléia , 6 5 bytes

ŒɠµJx

Experimente online!

Salvo um byte graças a UnrelatedString !

Entradas e saídas como array (com colchetes de abertura / fechamento)

Como funciona

ŒɠµJx - Main link, takes one argument:                       [7, 7, 5, 5, 5, 1]
Œɠ    - Get the lengths of consecutive elements:             [2, 3, 1]
  µ   - Call these lengths A
   J  - range(length(A))                                     [1, 2, 3]
    x - Repeat each element by the corresponding value in A: [1, 1, 2, 2, 2, 3]
caird coinheringaahing
fonte
5 bytes
Cadeia não relacionada
1
@UnrelatedString todos esses átomos novos!
caird coinheringaahing
2

05AB1E , 5 bytes

¥Ā.¥>

Experimente online!

Mr. Xcoder
fonte
Alternativa menor de 5 bytes: ¥Ātambém pode ser üÊ.
Kevin Cruijssen
1
4 bytes
Grimmy
2

Perl 6 , 21 bytes

{+<<[\+] $,|$_ Zne$_}

Experimente online!

Bloco de código anônimo que pega uma lista e retorna uma lista. Isso funciona comparando se cada par de elementos adjacentes não é igual, do que obtendo a soma acumulada da lista.

Brincadeira
fonte
2

05AB1E , 4 bytes

γdƶ˜

Experimente online!

γ       # group adjacent equal digits together
 d      # replace all digits with 1
  ƶ     # multiply each group by its 1-based index
   ˜    # flatten
Grimmy
fonte
Eu continuo esquecendo que 05ab1e tem que ƶ... +1
Mr. Xcoder 14/08
1
Aqui está um 4-byter alternativo:ηεγg
Kevin Cruijssen
2

R , 33 bytes

function(x)cumsum(c(1,!!diff(x)))

Experimente online!

Usa o mesmo método de soma acumulada que Luis Mendo e outros.

user2390246
fonte
2

MATL , 8 bytes

Y'wn:wY"

Experimente online!

Explicação:

    Y'      % run-length encoding
    w       % swap elements in stack
    n       % number of elements in array / size along each dimension
    :       % range; vector of equally spaced values
    w       % swap elements in stack
    Y"      % replicate elements of array
            % (implicit) convert to string and display
OrangeCherries
fonte
2

Gelatina , 4 bytes

ŒgƤẈ

Experimente online!

Quão?

ŒgƤẈ - Link: list of integers  e.g. [7,7,2,7,7]
  Ƥ  - for prefixes:     [7]   [7,7]   [7,7,2]      [7,7,2,7]        [7,7,2,7,7]
Œg   -   group runs      [[7]] [[7,7]] [[7,7],[2]]  [[7,7],[2],[7]]  [[7,7],[2],[7,7]]
   Ẉ - length of each    [1,   1,      2,           3,               3]
Jonathan Allan
fonte
1

Haskell , 46 43 bytes

scanl(+)1.map fromEnum.(zipWith(/=)=<<tail)

Experimente online!

Função pointfree anônima que pega uma lista e retorna uma lista

Brincadeira
fonte
1

Perl 5 , 27 bytes

s/\d/$i+=$&!=$p;$p=$&;$i/ge

Experimente online!

A opção de linha de comando -pfaz com que o perl leia a linha de entrada de STDIN na "variável padrão" $_. Em seguida, a pesquisa substitui todos os dígitos $_pelo contador $i. E $ié aumentado para cada dígito diferente do dígito anterior, que também está no primeiro dígito, portanto o contador inicia em 1. O dígito anterior é armazenado em $p.

Kjetil S.
fonte
1

Pitão , 13 11 bytes

s.e*]hkhbr8

Experimente online!

         r8  # Run-length encode (implicit argument is the input) (-> [[frequency, char], ...]
 .e          # Enumerated map (current element is b, index is k) over rQ8
   *]hk      # [ k+1 ] *
       hb    #           b[0]
s            # Reduce list on + ([a]+[b] = [a,b])

-2 bytes graças ao Sr. Xcoder

ar4093
fonte
hMsM._+0nVtpara -2 bytes.
Mr. Xcoder
Ou se você quer manter sua abordagem, rQ8é o mesmo que r8e .npode ser sde -2 bem
Sr. Xcoder
Ah, bom, os documentos não mencionaram que funções são implícitasQ
#
1

Scala , 75 bytes

s=>s.scanLeft(("",0))((x,y)=>(y,x._2+(if(x._1!=y)1 else 0))).tail.map(_._2)

Experimente online!

Se a entrada e a saída tiverem de ser separadas por vírgula, a sequência (e não a lista) será 102 bytes.

s=>s.split(", ").scanLeft(("",0))((x,y)=>(y,x._2+(if(x._1!=y)1 else 0))).tail.map(_._2).mkString(", ")
Dr. Y Wit
fonte
1

Gelatina , 5 bytes

nƝÄŻ‘

Experimente online!

Inicialmente, eu tinha como objetivo um 4-byter (o mesmo programa, mas sem o Ż), mas logo percebi que um 1 tinha que ser anexado todas as vezes devido a uma supervisão ... Mesmo que haja outro 5-byter em Jelly, eu vou Na verdade, mantenha isso porque ele usa um método diferente.

eueuEueuEu+1,1Eu<|eu|

Mr. Xcoder
fonte
Acho que não?
Mr. Xcoder
1

JavaScript (ES6), 30 bytes

Recebe a entrada como uma matriz de números inteiros.

a=>a.map(p=n=>i+=p!=(p=n),i=0)

Experimente online!

Comentado

a =>                // a[] = input array
  a.map(p =         // initialize p to a non-numeric value
  n =>              // for each value n in a[]:
    i +=            //   increment i if:
      p != (p = n), //     p is not equal to n; and update p to n
    i = 0           //   start with i = 0 (chunk counter)
  )                 // end of map()
Arnauld
fonte
1

PHP , 52 bytes

while(''<$d=$argv[++$x])echo$i+=$argv[$x-1]!=$d,' ';

Experimente online!

Entrada via linha de comando, saída para STDOUT.

Thx para @ Night2 para o traquina '0' == 0 correção de comparação !

640KB
fonte
@ Night2 boa captura! Atualizado e corrigido. Valeu!
640KB
1

Julia 1.0 , 56 bytes

l->foldl(l,init=(0,0))do(p,i),c
println(i+=p!=c)
c,i
end

Experimente online!

user3263164
fonte
0

Japt v2.0a0, 9 bytes

£T±A¦(A=X

Tente

Modalidade de ignorância
fonte
0

Adicionar ++ , 23 bytes

D,f,@*,BGd€bL$bLRz€¦XBF

Experimente online!

Como funciona

D,f,@*,     - Define a function, f, that takes one argument:  [7 7 5 5 5 1]
       BG   - Group neighbouring elements together:           [[[7 7] [5 5 5] [1]]]          
       d    - Duplicate:                                      [[[7 7] [5 5 5] [1]] [[7 7] [5 5 5] [1]]]
       €bL  - Get the length of each:                         [[[7 7] [5 5 5] [1]] [2 3 1]]
       $bLR - Length, then range of length:                   [[2 3 1] [1 2 3]]
       z    - Zip together:                                   [[2 1] [3 2] [1 3]]
       €¦X  - Reduce each by repetition:                      [[1 1] [2 2 2] [3]]
       BF   - Flatten:                                        [1 1 2 2 2 3]
            - Due to the * in the function definition,
                 return the whole stack:                      [1 1 2 2 2 3]
caird coinheringaahing
fonte
0

Retina 0.8.2 , 34 bytes

\b\d+\b(?<=(\b(\3|(\d+))\D*)*)
$#3

Experimente online! Explicação:

\b\d+\b

Combine cada número por vez.

(?<=(...)*)

Comece olhando para trás o maior número possível de correspondências. (As próximas entradas serão na ordem da direita para a esquerda, pois é assim que o lookbehind funciona.)

\D*

Pule os separadores.

(\3|(\d+))

Tente corresponder ao mesmo número da última vez, mas, na sua falta, basta corresponder a qualquer número, mas lembre-se de que tivemos que corresponder a um novo número.

\b

Verifique se o número inteiro é correspondido.

$#3

Conte o número de novos números.

Neil
fonte
0

Stax , 10 bytes

▓ª2ªmD?Ä╧╖

Execute e depure

A saída usa o espaço como um delimitador. A entrada segue as especificações precisas usando vírgulas como separadores e agora incluindo chaves.

recursivo
fonte
0

C (gcc) , 62 61 bytes

Esta é uma das poucas entradas que fiz quando um programa completo é mais curto que um envio de função!

Na primeira passagem, não me importo com o valor anterior, por isso confio no fato de que argvé um ponteiro para algum lugar e é extremamente improvável que esteja entre [0..9]!

s;main(i,j){for(;~scanf("%d,",&i);j=i)printf("%d ",s+=j!=i);}

Experimente online!

ErikF
fonte
0

Scala , 114 bytes

s.split(", ").zipWithIndex.scan(s.head,0){(a,b)=>if(a._1==b._1)a else b._1->(a._2+1)}.tail.unzip._2.mkString(", ")

Experimente online!

Ensaboado
fonte
0

C (gcc) , 62 bytes

f(_,l)int*_;{printf("%d ",l=--l?f(_,l)+(_[l]!=_[l-1]):1);_=l;}

Experimente online!

Uma função que leva a lista e seu comprimento como argumentos.


C (gcc) , 60 bytes

f(_,l)int*_;{_=printf("%*d",--l?f(_,l)+(_[l]!=_[l-1]):2,0);}

Experimente online!

Saídas em unário, delimitado por 0s

attinat
fonte