Encontre as ocorrências de um caractere em uma sequência de entrada

18

Desafio

Escreva um programa que, com uma sequência de x10 caracteres e um caractere y, produza o número de vezes que o caractere yocorre na sequência x.

O programa mais curto em bytes para fazer isso vence.

Exemplo

Input: tttggloyoi, t
Output: 3

Input: onomatopoe, o
Output: 4
rosslyn taghoy
fonte
11
Parece um desafio quase fácil demais. Além disso, por que limitar a entrada a 10, em vez de nenhum limite?
Fatalize
7
Precisa de uma condição vencedora.
Isaacg 02/09/2015
2
Sinta-se livre para reverter a minha edição se não concordar com você
Beta Decay
8
Quão flexível é o formato de entrada? Podemos escolher um delimitador diferente, como um espaço ou uma nova linha? A string pode estar entre aspas? Podemos pegar a letra primeiro e a corda depois? Os caracteres sempre serão minúsculos? Caso contrário, quais outros caracteres podem ocorrer?
Martin Ender
5
Este parece suspeito como uma questão entrevista C ...
Quentin

Respostas:

18

Pitão, 3 bytes

/ww

Exemplo de execução:

$ pyth -c '/ww'
sdhkfhjkkj
k
3

Obviamente, o usuário pode inserir mais ou menos de 10 letras na primeira entrada, mas não precisamos nos preocupar com o que acontece quando o usuário viola as especificações.

isaacg
fonte
Parece que isso não é mais um piton válido?
Ven
explicação por favor?
MilkyWay90
@ MilkyWay90 Eis como você pode usar isso: Experimente online! . /conta apenas o número de ocorrências na primeira sequência de entrada da segunda sequência de entrada. wpega uma linha de entrada.
isaacg 15/10
@isaacg oh, entendo. Obrigado!
MilkyWay90 16/10
11

Pitão - 3 bytes

Uma resposta Pyth diferente, menos óbvia, do mesmo tamanho. Dobra contando sobre a entrada.

/FQ

Conjunto de Teste .

Maltysen
fonte
7

JavaScript, 32

(p=prompt)().split(p()).length-1
edc65
fonte
6

Bash, 24 caracteres

x=${1//[^$2]}
echo ${#x}

Exemplo de execução:

bash-4.3$ bash letter-count.sh tttggloyoi t
3

bash-4.3$ bash letter-count.sh onomatopoe o
4
homem a trabalhar
fonte
6

Retina , 12 bytes

(.)(?=.*\1$)

Simplesmente uma regex que corresponde a um caractere igual ao último caractere na entrada (exceto ele próprio). Quando recebe uma única regex, o Retina simplesmente retorna o número de correspondências.

Martin Ender
fonte
Uau, eu estou aqui tentando fazer todo tipo de coisas chiques com rs , e você me venceu com olhares. 1
kirbyfan64sos
4

Labirinto , 32 29 27 24 bytes

),}{)-
@ ,  +);__
!-`{:}

Isso lê o caractere único primeiro, seguido pela sequência na qual contar e assume que não há bytes nulos na sequência.

Explicação

O código começa com ),}, que define a parte inferior da pilha 1, lê o primeiro caractere e o move para a pilha auxiliar para uso futuro. O 1contador será nosso (o deslocamento de 1 será cancelado posteriormente e é necessário que o IP faça as curvas necessárias).

O IP agora será movido para baixo para ler o primeiro caractere da string de pesquisa ,. O valor é negado com `, novamente, para obter o comportamento correto de rotação. Enquanto estivermos lendo caracteres do STDIN, o IP agora segue este loop:

  }{)-
  ,  +);__
  `{:}

{:}faz uma cópia do código de caractere armazenado e o +adiciona ao valor atual. Se o resultado for 0(ou seja, o personagem atual é o que estamos procurando), o IP avança: -simplesmente se livra do 0, )incrementa o contador, {}é um não-op.

No entanto, se o resultado depois +for diferente de zero, não queremos contar o caractere atual. Portanto, o IP vira à direita. Esse é um beco sem saída, para que o código seja executado duas vezes, uma para frente e outra para trás. Ou seja, o código real nesse caso se torna );___;)+-){}. );apenas se livra dessa diferença diferente de zero, ___pressiona 3 zeros, mas ;descarta um deles. )incrementa um dos dois zeros restantes, os +adiciona em um único 1, -subtrai do contador e )incrementa o contador. Em outras palavras, criamos um no-op muito elaborado.

Quando atingimos o EOF, ,empurra -1, que `se transforma 1e o IP vira à direita. -subtrai o 1do contador (cancelando o deslocamento inicial). !imprime o contador e @finaliza o programa.

Martin Ender
fonte
4

Python 3, 29 bytes

print(input().count(input()))

Meh, isso foi fácil. Supõe que a entrada seja uma sequência de dez letras.

Beta Decay
fonte
4
Você me copiou! : D
isaacg 02/09/2015
1
@isaacg Grandes mentes pensam da mesma forma? ; D
Beta Decay
Se você não precisar ler as entradas, não f=lambda x,y:x.count(y)seria mais curto? (Desculpe se isso não funcionar, eu estou no celular e não pode verificar)
cole
@ mbomb007 Meu erro, obrigado por esclarecer.
Cole
1
Removendo os suportes em torno de impressão poupa um personagem print input().count(input())ou a,b=input();print a.count(b)com a mesma quantidade
Willem
4

Boneco de neve 1.0.2 , 16 caracteres

~vgvgaSaLNdEtSsP

Surpreendentemente curto. Explicação:

~      make all vars active (even though we only need two, we don't really care)
vgvg   get two lines of input
aS     split first line on second line
aL     length of the new array
NdE    decrement (because ex. "axbxc""x"aS -> ["a" "b" "c"] which is length 3)
tSsP   to-string and print
Maçaneta da porta
fonte
Bom trabalho! Eu não pensaria que uma solução tão curta seria possível no Snowman.
Alex A.
4

Metaprogramação de modelos em C ++, 160 154 116 bytes

Apenas pelas risadinhas.

Obrigado ao ex-bart por jogar golfe!

template<int w,int x,int y,int...s>class A:A<w+(x==y),x,s...>{};A<0,'t','t','t','t','g','g','l','o','y','o','i',0>a;

Uso: O primeiro caractere na instanciação do modelo é o caractere a ser pesquisado.

Conclua com clang -std = c ++ 11 -c -> o resultado está no início da mensagem de erro.

Occurences.cpp:1:66: error: too few template arguments for class template 'A'
template<int w,char x,char y,char...s>class A{static const int a=A<w+((x==y)?1:0),x,s...>::a;};
                                                             ^
Occurences.cpp:1:66: note: in instantiation of template class 'A<3, 't', '\x00'>' requested here
template<int w,char x,char y,char...s>class A{static const int a=A<w+((x==y)?1:0),x,s...>::a;};

Conclua com gcc -std = c ++ 11 -c -> o resultado está na parte inferior da mensagem de erro.

Occurences.cpp: In instantiation of ‘const int A<3, 't', '\000'>::a’:
Occurences.cpp:1:64:   recursively required from ‘const int A<1, 't', 't', 't', 'g', 'g', 'l', 'o', 'y', 'o', 'i', '\000'>::a’
Occurences.cpp:1:64:   required from ‘const int A<0, 't', 't', 't', 't', 'g', 'g', 'l', 'o', 'y', 'o', 'i', '\000'>::a’
Occurences.cpp:2:62:   required from here
Occurences.cpp:1:64: error: wrong number of template arguments (2, should be at least 3)

Pesquise A < 3 , 't', '\ 000'> e A < 3 , 't', '\ x00'>

Versão de 154 bytes

template<int w,char x,char y,char...s>class A{static const int a=A<w+(x==y),x,s...>::a;};                          
int a=A<0,'t','t','t','t','g','g','l','o','y','o','i','\0'>::a;

Versão de 160 bytes:

template<int w,char x,char y,char...s>class A{static const int a=A<w+((x==y)?1:0),x,s...>::a;};                          
int a=A<0,'t','t','t','t','g','g','l','o','y','o','i','\0'>::a;
Otomo
fonte
Você pode reduzir ((x==y)?1:0)para (x==y)economizar apenas 6 bytes (eu acho).
Kirbyfan64sos #
Obrigado - queria ter certeza de que é um comportamento definido, porque eu não tinha certeza do que o padrão dizia sobre boola intconversão.
Otomo
É um comportamento definido.
Kirbyfan64sos #
Sim, agora eu também sei disso. :) Muito obrigado. (Eu pensei que talvez seria dependente de implementação.)
Otomo
1
128 bytes: use anônimo em enumvez de static const. Use em 0vez de '\0'para finalizar. Use em intvez de char. Use uma declaração ligeiramente diferente para instanciar. Remova a nova linha superflouos. template<int w,int x,int y,int...s>class A{enum{a=A<w+(x==y),x,s...>::a};};A<0,'t','t','t','t','g','g','l','o','y','o','i',0>a;. Verificado com g ++ e clang.
ex-bart
3

Bash + grep, 26 bytes

grep -o "$1"<<<"$2"|wc -l
Tarod
fonte
3

Javascript (ES6), 26 bytes

(a,b)=>a.split(b).length-1

Essa solução rápida e fácil define uma função anônima. Para usá-lo, adicione uma declaração de variável ao início. Experimente:

EDIT: Ah, vejo que já existe uma solução muito semelhante. Espero que esteja tudo bem.

ETHproductions
fonte
3

Haskell, 21 bytes

a!b=sum[1|x<-a,x==b]
Otomo
fonte
3

C ++, 78 bytes

int main(int,char**v){int c=0,i=0;while(i<10)v[1][i++]==*v[2]&&++c;return c;}

Ligue assim:

$ g++ -std=c++14 -O2 -Wall -pedantic -pthread main.cpp && ./a.out tttggloyoi t; echo $?
3
ex-bart
fonte
3

Elemento , 23 bytes

__);11'[)\
~="0 1@][+]`

A nova linha faz parte do programa. Na verdade, estou usando-o como um nome de variável .

Esse programa basicamente funciona armazenando o caractere de destino em uma variável, mantendo a string atual no topo da pilha e, em seguida, repetindo o processo "cortar, comparar e mover o resultado por baixo", somando os resultados no final.

A nova linha como um nome de variável vem do uso da nova linha no final da entrada, cortando-a e armazenando nela. A nova linha no código é onde eu li.

A entrada é assim:

qqqqwwweee
q

A saída é assim

4
PhiNotPi
fonte
3

Julia, 26 25 bytes

f(s,c)=endof(findin(s,c))

A findinfunção retorna os índices no primeiro argumento no qual o segundo argumento é encontrado como um vetor. O comprimento do vetor é o número de ocorrências.

Guardou um byte graças a Glen O.

Alex A.
fonte
endofeconomizará um byte no lugar de length.
Glen O
3

APL, 7 3 bytes

+/⍷

Isso cria um trem de função. Ele funciona criando um vetor de zeros e aqueles correspondentes aos índices nos quais o caractere aparece na string ( ). O vetor é então somado ( +/).

Guardado 4 bytes graças a kirbyfan64sos e NBZ!

Alex A.
fonte
APL é curry como K? Eu acho que você poderia fazer algo assim +/⍷(eu não sei APL, então posso estar errado).
Kirbyfan64sos #
@ kirbyfan64sos O único curry que conheço é comida, então não tenho certeza. Mas vou dar uma olhada. Obrigado pela sugestão!
Alex A.
@ kirbyfan64sos Sim, é chamado de trem de função , então + / ⍷ funcionaria de fato, mas como estamos procurando um único caractere, pode-se usar = em vez de ⍷.
Adám
3

Perl, 21 16 caracteres

(Código de 13 caracteres + opção de linha de comando de 3 caracteres.)

$_=0+s/$^I//g

Exemplo de execução:

bash-4.3$ perl -it -pe '$_=0+s/$^I//g' <<< tttggloyoi
3

bash-4.3$ perl -io -pe '$_=0+s/$^I//g' <<< onomatopoe
4

bash-4.3$ perl -i5 -pe '$_=0+s/$^I//g' <<< 1234
0
homem a trabalhar
fonte
Truque puro com <>!
precisa saber é o seguinte
Você pode salvar um byte descartando -le garantindo que sua entrada não tenha uma nova linha à direita:echo -en 'onomatopoe\no' | perl -pe '$_=eval"y/".<>."//"'
ThisSuitIsBlackNot 2/15/15
1
E você pode reduzir seu total para 16 comperl -pe '$_+=s/${\<>}//g'
ThisSuitIsBlackNot 2/15/17
Esse truque de referência é incrível. Obrigado, @ThisSuitIsBlackNot.
manatwork
Por que o +=necessário? =parece funcionar tão bem (e ainda deve funcionar quando a entrada começa com alguns dígitos).
ex-bart
3

PHP, 36 35 bytes

<?=substr_count($argv[1],$argv[2]);


Uso:
chame o script com dois argumentos.
php script.php qwertzqwertz q

PHP, 23 bytes

Se você registrar Variáveis ​​globais (somente possível no PHP 5.3 e abaixo), poderá salvar 12 bytes (graças a Martijn )

<?=substr_count($a,$b);


Uso:
chame o script e declare variáveis ​​globaisphp script.php?a=qwertzqwertz&b=q

empurrão
fonte
1
Você pode remover um espaço após a vírgula para obter um byte menos
Voitcus
1
Se você registrar globais que você pode fazer script.php?a=qwertzqwertz&b=q, e fazer <?=substr_count($a,$b);, 23 caracteres
Martijn
@ Martijn boa ideia obrigado!
jrenk
3

Dyalog APL , 3 bytes

      +/=

Ou seja, "A soma dos bytes iguais". Por exemplo:

      f ← +/=
      'onomatopoe' f 'o'
4

ou apenas

      'onomatopoe'(+/=)'o'
4

K não vence APL neste momento.

Experimente online.

Adão
fonte
Por favor, não edite dezenas de postagens de uma só vez. Você está inundando completamente a primeira página. Se houver muitas postagens que precisam ser editadas (o que ocasionalmente acontece, por exemplo, porque uma nova tag foi adicionada), geralmente é bom fazer apenas três delas de cada vez e esperar pelo menos 12 horas para que elas saiam da frente página.
Martin Ender
@ MartinBüttner Sim, eu não percebi na época. :-( Usuários regulares não têm a opção "
Edição secundária
Infelizmente, não existe essa opção, nem mesmo para moderadores.
Martin Ender
3

T-SQL, 99 40 bytes

SELECT 11-LEN(REPLACE(s,c,'')+'x')FROM t

Simplesmente faz a diferença entre a string de entrada e a string com o caractere removido. Recebe informações da tabela t

A edição foi alterada para remover um problema na contagem de espaços e levar em consideração as entradas aceitáveis ​​atuais para o SQL. Obrigado @BradC por todas as alterações e economias

MickyT
fonte
Você não deve precisar de todos os andaimes, basta fazer SELECT LEN(s)-LEN(REPLACE(s,c,''))FROM t, onde t há uma tabela de entrada pré-preenchida com campos se c.
BradC 10/10
Em outra nota, esse código fornece a resposta errada para cadeias como A B C D essa que terminam em espaços (se você for solicitado a contar espaços), pois LENignora os espaços finais.
BradC 10/10
@ BradC Eu acho que, naquela época, as regras em torno do que era aceitável, especialmente em torno do SQL, eram restritivas e pouco claras. Vou dar uma olhada na space
solução
Eu costumo apenas preencher o final e subtrair um; neste caso, a entrada é garantida com exatamente 10 caracteres, você pode apenas codificá-la comoSELECT 11-LEN(REPLACE(s,c,'')+'x')FROM t
BradC
@ BradC, sim, olhando para isso de novo, não sei por que permiti comprimento variável. Fazendo mudanças.
MickyT 10/10
2

Oitava / Matlab, 33 bytes

sum(input('','s')==input('','s'))
Luis Mendo
fonte
2

J, 5 bytes

+/@:=

Sinto que J teria um built-in para isso, mas não consegui encontrar um - talvez um dos usuários ativos de J possa me esclarecer. Então, ao invés disso, isso se aplica primeiro =às entradas, transformando cada caractere 1se for igual ao solicitado ou 0não. Então +/calcula a soma dessa lista.

Martin Ender
fonte
2

Arquivo em lote, 121 bytes

Porque eu sou masoquista ...

SET c=0
SET e=_
SET t=%1%%e%
:l
SET a=%t:~0,1%
IF "%a%"=="%2" SET /A c+=1
SET t=%t:~1%
IF NOT "%t%"=="%e%" GOTO l
ECHO %c%

Aviso: Supõe que _isso não ocorra na sequência de entrada. Nesse caso, a variável eprecisa ser ajustada adequadamente.

Isso configura nossa variável de contador c, e nossa demarcação de fim de sequência como _, antes de anexá-la à nossa sequência de entrada %1e definir a sequência concatenada como t. Então, estamos entrando em loop :l, definimos uma variável de caractere temporário apara ser o primeiro caractere t, verifique se ela corresponde à nossa segunda string de entrada %2e incrementoc se true, e apare o primeiro caractere t. Nossa condição de fim de loop é tcomparada à demarcação de fim de string e retorna, se não. Em seguida, echoeliminamos o valor do nosso contador.

Provavelmente seria possível usar um FORloop, mas isso exigiria a ativação da DelayedExpansion , que eu acho que será mais longa em bytes do que isso. A verificação disso é deixada como um exercício para o leitor.

AdmBorkBork
fonte
2

CJam, 5 bytes

ll/,(

Explicação

l      e# read x
 l     e# read y
  /    e# split x by y
   ,   e# count
    (  e# subtract one
Ypnypn
fonte
2

PowerShell, 32 bytes

Um quatro por um! E eles são todos do mesmo comprimento! :)

($args[0]-split$args[1]).Count-1

ou

param($a,$b)($a-split$b).Count-1

Alternativamente,

$args[0].Split($args[1]).Count-1

ou

param($a,$b)$a.Split($b).Count-1

Os dois primeiros estilos usam o operador inline -split, enquanto os dois segundos lançam implicitamente o primeiro argumento como uma String e usam o.Split() operador baseado em string. Em todos os casos, uma matriz é retornada, onde devemos decrementar Count por um, pois estamos recebendo de volta mais um item da matriz do que as ocorrências do segundo argumento.

Esse foi meio divertido ...

AdmBorkBork
fonte
2

Julia, 21 bytes

f(s,c)=sum(i->c==i,s)

Observe que exige que cseja um caractere, não uma sequência de caracteres únicos. Então você o usa como f("test me",'e')(que retorna 2) e não f("test me","e")(que retorna 0, porque 'e'!="e").

Glen O
fonte
2

> <> (Peixe) , 30 bytes

0&v
=?\ilb
=?\:@=&+&l1
n&/;

Pega a string e, em seguida, o caractere para contar. A entrada não está separada (pelo menos no intérprete online). Experimente no intérprete on-line: http://fishlanguage.com Eu contei os bytes manualmente, então, deixe-me saber se estou errado.

Explicação

Primeiro,> <> é bidimensional ee percorre uma linha ou coluna até encontrar um ;erro. Isso significa que, se continuar da esquerda para a direita (como acontece no início de um programa), ele contornará a linha se chegar ao fim e não for movido ou instruído para interromper o programa. Alguns caracteres por linha serão repetidos porque têm funções diferentes, dependendo da direção do ponteiro, e a quarta linha terá caracteres na ordem inversa, porque o ponteiro se move da direita para a esquerda.

Um resumo do programa é fornecido abaixo. Veja as instruções listadas para> <> nos esolangs para ver o que cada caractere individual faz.

Linha 1: 0&v

0&v -put 0 into the register and change direction to down-up

Linha 2: =?\ilb

(começando onde a linha 1 move o ponteiro para, ou seja, o terceiro caractere)

\ -reflect the pointer and make it move left-right
i -read input
lb=?\ -reflect downwards if there are 11 values in the stack

linha 3: =?\:@=&+&l1

(começando no terceiro caractere)

:@ -duplicate y and shift the stack e.g. ['x','y','y'] -> ['y','x','y']
=&+& -increment the register if the character popped from x = y
l1=?\ -reflect downwards if there is 1 value in the stack

Linha 4: n&/;

(começando no terceiro caractere)

/ -reflect right-left
&n; -print value of the register
Cole
fonte
2

Ruby, 22 20 bytes

p gets.count(gets)-1

Demonstração: http://ideone.com/MEeTd2

O -1é devido ao fato de que getsrecupera a entrada, além de um caractere de nova linha. Ruby String#countconta o número de vezes que qualquer caractere do argumento ocorre na string.

Por exemplo, para a entrada [ test\n, t\n], tocorre duas vezes e \nocorre uma vez e precisa ser subtraído.

Cristian Lupascu
fonte
Você pode remover $><<e reduzir 4 bytes.
Vasu Adari
@VasuAdari mas eu preciso imprimir o resultado de alguma forma ...
Cristian Lupascu
você não pode fazer isso? ->p gets.count(gets)-1
Vasu Adari
@VasuAdari Você está certo; no momento, pensei que isso iria colocar em questão a saída, mas é numérico, então está tudo bem. Obrigado!
Cristian Lupascu
2

Ruby, 18 bytes

->s,c{p s.count c}

Uso:

->s,c{p s.count c}.call 'tttggloyoi', 't'

->s,c{p s.count c}.call 'onomatopoe', 'o'
Vasu Adari
fonte