Encontre os índices de valores em uma lista em outra

21

Você deve usar duas listas de números inteiros positivos como entrada, vamos chamá-los de n e m .

Você pode assumir que:

  • Todos os números inteiros em n fazem parte de m
  • Todos os números inteiros em m são únicos
  • As listas não estão vazias

Desafio: retorne os índices de onde você encontra os valores em n , em m .

Isso pode ser confuso, mas acho que os casos de teste tornarão a tarefa bem clara. Os exemplos são indexados em 1, você pode escolher indexado em 0 se desejar (especifique).

n = 5 3 4 1
m = 6 8 4 1 2 5 3 100
output: 6 7 3 4    // 5 is in the 6th position of m 
                   // 3 is in the 7th position of m
                   // 4 is in the 3rd position of m
                   // 1 is in the 4th position of m

n = 5 3 4 9 7 5 7
m = 3 4 5 7 9
output: 3 1 2 5 4 3 4

n = 1 2 3 4 5 6
m = 1 2 3 4 5 6
output: 1 2 3 4 5 6

n = 16 27 18 12 6 26 11 24 26 20 2 8 7 12 5 22 22 2 17 4
m = 15 18 11 16 14 20 37 38 6 36 8 32 21 2 31 22 33 4 1 35 3 25 9 30 26 39 5 23 29 10 13 12 7 19 24 17 34 27 40 28
output: 4 38 2 32 9 25 3 35 25 6 14 11 33 32 27 16 16 14 36 18

n = 54
m = 54
output: 1

Os vencedores serão as soluções mais curtas em cada idioma.


A propósito, este é um meta-post muito bom!

Stewie Griffin
fonte
Essa pode ser uma pergunta estranha, mas seria aceitável supor que a entrada terá um espaço à direita?
DJMcMayhem
Curioso porque você perguntar, mas sim, claro ...
Stewie Griffin

Respostas:

13

V , 26 bytes

jòdf kÄ/-
DÓÓ
ÒC1@"Gòdk

Experimente online!

Esta é uma solução muito estranha e hacky, porque V tem pouco ou nenhum conceito de números. A entrada vem neste formato:

6 8 4 1 2 5 3 100 
5 3 4 1 

Com um espaço à direita em cada linha.

Hexdump:

00000000: 6af2 6466 206b c42f 122d 0a44 d3d3 0ad2  j.df k./.-.D....
00000010: 0143 311b 4022 47f2 646b                 .C1.@"G.dk

Explicação:

j                   " Move down one line (to N) (1)
 ò                  " Recursively:
  df                "   (d)elete until you (f)ind a space. This will be saved into
                    "   register '-' (2)
     k              "   Move up one line (to M)
      Ä             "   Duplicate line M (3)
       /<C-r>-      "   Move the cursor forward until the next occurence of register '-' 
                    "   (the number we deleted from N)
                    "   (4)
D                   "   Delete every character *after* the cursor (5)
 ÓÓ                 "   Remove everything on this line except for whitespace
Ò<C-a>              "   Replace every character on this line with `<C-a>`, which is the 
                    "   command for incrementing a number (6)
      C             "   Delete this line into register '"', and enter insert mode
       1<esc>       "   Enter a '1' and return to normal mode
             @"     "   Run register '"' as V code (7)
               G    "   Go to the last line (1)
                ò   " End recursion
                 dk " Delete the last two lines (m and n)

Se isso não esclarecer, aqui estão alguns exemplos do buffer durante os vários estágios pelos quais o loop passa:

Etapa 1 ( |é o cursor)

6 8 4 1 2 5 3 100
|5 3 4 1

Etapa 2:

6 8 4 1 2 5 3 100
|3 4 1

Etapa 3:

|6 8 4 1 2 5 3 100
6 8 4 1 2 5 3 100
3 4 1

Etapa 4:

6 8 4 1 2 |5 3 100
6 8 4 1 2 5 3 100
3 4 1

Etapa 5:

6 8 4 1 2 |
6 8 4 1 2 5 3 100
3 4 1

Etapa 6:

|<C-a><C-a><C-a><C-a><C-a>
6 8 4 1 2 5 3 100
3 4 1

Etapa 7:

|6
6 8 4 1 2 5 3 100
3 4 1

De volta ao estágio 1:

6
6 8 4 1 2 5 3 100
|3 4 1
DJMcMayhem
fonte
9

Python 2 , 25 bytes

lambda a,b:map(a.index,b)

Experimente online!

Observe que isso usa indexação 0.

Freira Furada
fonte
8

APL (Dyalog) , 1 byte

Experimente online!

Nota: a função não aceita escalares como argumento à esquerda; portanto, para fornecer um argumento à esquerda como 54, você deve transformá-lo em uma matriz usando ,assim (,54).

Kritixi Lithos
fonte
7

Mathematica, 25 bytes

#&@@@PositionIndex@#/@#2&

Toma duas entradas me n, e retorna os índices baseados em 1 de nin m.

Martin Ender
fonte
6

Retina , 32 31 30 bytes

1 byte economizado graças a Kritixi Lithos e 1 byte graças a Martin Ender

(\d+)(?=.*¶(\d+ )*\1 )
$#2
G1`

Usa indexação 0. A entrada possui um espaço à direita em cada linha.

Experimente online!

Explicação

(\d+)(?=.*¶(\d+ )*\1 )
$#2

Aqui, substituímos todos os números na primeira linha pelo número de números antes do mesmo número na segunda linha.

G1`

Em seguida, excluímos a segunda linha, deixando apenas a nova primeira linha como saída.

Gato de negócios
fonte
5

Java , 104 81 bytes

1 byte graças ao Business cat.

void f(int[]a,int[]b){for(int i=0,j=0;i<b.length;)j=a[j++]==b[i]?0*(b[i++]=j):j;}

Experimente online!

Freira Furada
fonte
5

C #, 32 bytes

(n,m)=>n.Select(i=>m.IndexOf(i))

Este é o código como uma expressão lambda, portanto deve ser válido.

A solução está com um índice baseado em 0. Eu acho que é bem direto como ele funciona - ele simplesmente pega os itens de n e seleciona os índices dos itens em m.

MetaColon
fonte
4

Oitava, 25 bytes

@(n,m)([x,~]=find(n==m'))

Experimente online!

rahnema1
fonte
4

Haskell , 32 bytes

a%b=[length$fst$span(/=x)b|x<-a]

Experimente online! Um indexado.

Outras tentativas:

q(h:t)x|x==h=0|1>0=1+q t x;map.q
f b=map$length.fst.($b).span.(/=)
a%b=[until((==x).(b!!))(+1)0|x<-a]
a%b=[until(\y->x==b!!y)(+1)0|x<-a]
import Data.List;map.flip elemIndex
xnor
fonte
3

k, 1

Este é um operador interno ke usa indexação baseada em zero.

?

Exemplo:

k)6 8 4 1 2 5 3 100 ? 5 3 4 1
5 6 2 3
skeevey
fonte
2

05AB1E , 5 bytes

v²yk,

Experimente online!

v     # For each value in n (call it y)
 ²    # Push m
  y   # Push y
   k, # Print the 0-indexed index of y in m
Riley
fonte
2

Gelatina , 3 bytes

iЀ

Experimente online!

Especificações

  • Entrada: dois argumentos, o primeiro sendo m e o segundo sendo n .
  • Saída: uma matriz
Freira Furada
fonte
2

JavaScript (ES6), 28 bytes

Pega as matrizes em currying sintaxe (n)(m). Indexado a 0.

let f =

n=>m=>n.map(v=>m.indexOf(v))

console.log(JSON.stringify(f([5,3,4,1])([6,8,4,1,2,5,3,100])))
console.log(JSON.stringify(f([5,3,4,9,7,5,7])([3,4,5,7,9])))
console.log(JSON.stringify(f([1,2,3,4,5,6])([1,2,3,4,5,6])))
console.log(JSON.stringify(f([16,27,18,12,6,26,11,24,26,20,2,8,7,12,5,22,22,2,17,4])([15,18,11,16,14,20,37,38,6,36,8,32,21,2,31,22,33,4,1,35,3,25,9,30,26,39,5,23,29,10,13,12,7,19,24,17,34,27,40,28])))
console.log(JSON.stringify(f([54])([54])))

Arnauld
fonte
2

Perl 6 , 31 bytes

->\n,\m{n.map:{m.first($_,:k)}}

Tente

Expandido:

-> \n, \m {  # pointy block lambda

  n.map: {            # map over the values in 「n」
    m.first( $_, :k ) # return the key 「:k」 of the first occurrence
  }
}

0 indexado

Brad Gilbert b2gills
fonte
2

Japonês , 4 bytes

m!bV

Teste online!

Explicação

Não há muito o que explicar aqui, mas mostra uma característica interessante do Japt. Normalmente, você passaria uma função para m:

mX{VbX}

Isso é basicamente U.map(X => V.indexOf(X))(o que Uestá implícito). No entanto, quando você está apenas executando uma operação entre dois valores ( baqui, on Ve X), você pode apenas dar ao operador e o outro valor e o Japt fará uma função com isso. Isso significa que você mX{X+2}pode jogar golfe param+2 .

No entanto, isso não funciona quando os valores estão na ordem errada ( mbVseria abreviação de mX{XbV}). Para contornar isso, você pode acrescentar um ponto de exclamação ao operador, que informa ao Japt para trocar os operandos. Isso custa um byte extra, mas ainda é um par de bytes mais curto que o alternativo. E agora você sabe um pouco mais sobre o Japt.

ETHproductions
fonte
2

MATL , 2 bytes

&m

Isso usa 1 indexação. Experimente online!

Explicação

A meta-função &indica que a próxima função usará uma especificação secundária de entrada / saída padrão (específica da função). Para function m( ismember), &especifica que sua segunda saída será produzida. Contém o índice de (a primeira ocorrência de) cada entrada da primeira entrada na segunda entrada.

Luis Mendo
fonte
2

Haskell, 34 bytes

n#m=[i|a<-n,(i,e)<-zip[1..]m,e==a]

Exemplo de uso: [5,3,4,9,7,5,7] # [3,4,5,7,9]->[3,1,2,5,4,3,4]

O built-in elemIndexé Data.Liste, portanto, mais longo que a versão acima. O loop externo passa ne o loop interno passa por pares de (i,e)onde ié o índice de ein m. Mantenha o ionde eé igual ao elemento atual de n.

nimi
fonte
2

R, 20 5 bytes

Indexado 1; matché a função embutida que encontra os índices na segunda entrada dos elementos da primeira, ou seja, match(n,m)fornece a resposta desejada

match

obrigado a @flodel por apontar que retornar uma função é perfeitamente aceitável como resposta!

Experimente online!

Giuseppe
fonte
2
Eu acho que match(5 bytes) por si só seria uma solução aceitável.
Flode 02/05
você está correto, atualizado.
Giuseppe
1

J , 2 bytes

i.

Este não é um programa completo, mas uma função interna.

Use-o como tal:

echo 6 8 4 1 2 5 3 100 i. 5 3 4 1

Experimente online!

Observe que isso usa indexação 0.

Freira Furada
fonte
1

CJam , 4 bytes

{f#}

Bloco anônimo que espera argumentos na pilha e deixa o resultado na pilha.

Usa indexação 0.

Experimente online!

Gato de negócios
fonte
1

Haskell, 43 bytes

a*b=[[fst x|x<-zip[0..]b,y==snd x]!!0|y<-a]
a*b=                                         -- define function * with 2 args
    [                                |y<-a]  -- for each elt in first arg
               zip[0..]b                     -- match elts in second arg w/ idxs
                                             -- [a,b,c] -> [[0,a],[1,b],[2,c]]
     [fst x|x<-                  ]           -- take first element in each pair
                        ,y==snd x            -- if the index matches
                                  !!0        -- first element (always only 1)
Maçaneta da porta
fonte
1

Clojure, 25 bytes

#(map(zipmap %2(range))%)

Indexado a 0.

NikoNyrh
fonte
1

Perl 5, 38 34 bytes

4 bytes salvos graças ao Dada

sub{map$x{$_}//($x{$_}=++$x)x0,@_}

1 indexado. Toma as listas m e n como uma única lista, como f(@m,@n). O x0é apenas para impedir que a saída comece 1,2,3,4,5, etc.

Chris
fonte
Boa resposta. Observe que funções anônimas são permitidas, portanto, sub{...}você pode economizar 2 bytes. Além disso, você pode usar em x0vez de &&()salvar mais dois bytes.
Dada
1

PHP, 56 bytes

Versões Online

0 Indexação

saída como String

<?foreach($_GET[0]as$v)echo" ".array_flip($_GET[1])[$v];

PHP, 65 bytes

Saída como matriz

<?foreach($_GET[0]as$v)$r[]=array_flip($_GET[1])[$v];print_r($r);

PHP, 78 bytes

solução alternativa com array_map

<?print_r(array_map(function($v){return array_flip($_GET[1])[$v];},$_GET[0]));

para matrizes não exclusivas, substitua por array_flip($_GET[1])[$v] array_search($v,$_GET[1])

Jörg Hülsermann
fonte
0

Bash + coreutils, 51

for n in $1
do grep -wn $n <<<"$2"
done|cut -d: -f1

Experimente online .


Resposta anterior:

s()(sort -$1k2)
nl|s|join -j2 - <(nl<<<"$1"|s)|s n|cut -d\  -f3

Experimente online .

Trauma Digital
fonte
0

Java 7, 80 bytes

void c(int[]a,java.util.List b){for(int i=0;i<a.length;a[i]=b.indexOf(a[i++]));}

Indexado a 0

Explicação:

void c(int[]a,java.util.List b){  // Method with integer-array and List parameters
  for(int i=0;i<a.length;         //  Loop over the integer-array
    a[i]=b.indexOf(a[i++])        //   And change every value to the index of the List
  );                              //  End of loop (no body)
}                                 // End of method

Código do teste:

Experimente aqui.

import java.util.Arrays;
class M{
  static void c(int[]a,java.util.List b){for(int i=0;i<a.length;a[i]=b.indexOf(a[i++]));}

  public static void main(String[] a){
    int[] x = new int[]{ 5, 3, 4, 1 };
    c(x, Arrays.asList(6, 8, 4, 1, 2, 5, 3, 100));
    System.out.println(Arrays.toString(x));

    x = new int[]{ 5, 3, 4, 9, 7, 5, 7 };
    c(x, Arrays.asList(3, 4, 5, 7, 9));
    System.out.println(Arrays.toString(x));

    x = new int[]{ 1, 2, 3, 4, 5, 6 };
    c(x, Arrays.asList(1, 2, 3, 4, 5, 6));
    System.out.println(Arrays.toString(x));


    x = new int[]{ 16, 27, 18, 12, 6, 26, 11, 24, 26, 20, 2, 8, 7, 12, 5, 22, 22, 2, 17, 4 };
    c(x, Arrays.asList(15, 18, 11, 16, 14, 20, 37, 38, 6, 36, 8, 32, 21, 2, 31, 22, 33, 4, 1, 35, 3, 25, 9, 30, 26, 39, 5, 23, 29, 10, 13, 12, 7, 19, 24, 17, 34, 27, 40, 28));
    System.out.println(Arrays.toString(x));


    x = new int[]{ 54 };
    c(x, Arrays.asList(54));
    System.out.println(Arrays.toString(x));
  }
}

Saída:

[5, 6, 2, 3]
[2, 0, 1, 4, 3, 2, 3]
[0, 1, 2, 3, 4, 5]
[3, 37, 1, 31, 8, 24, 2, 34, 24, 5, 13, 10, 32, 31, 26, 15, 15, 13, 35, 17]
[0]
Kevin Cruijssen
fonte