Знайдіть індекси значень в одному списку в іншому


21

Ви повинні взяти два списки натуральних чисел як вхідні дані, назвемо ці n і m .

Ви можете припустити, що:

  • Всі цілі числа в n є частиною m
  • Всі цілі числа в m є унікальними
  • Списки не порожні

Завдання: Поверніть показники, де ви знайдете значення в n , в m .

Це може бути заплутаним, але я думаю, що тестові випадки зроблять завдання досить зрозумілим. Приклади є 1-індексованими, ви можете обрати 0-індексований, якщо хочете (вкажіть).

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

Переможцями будуть найкоротші рішення з кожної мови.


Це дуже приємний метапост!


Це може бути дивним питанням, але чи було б нормальним припустити, що вхід матиме пробіл?
DJMcMayhem

Цікаво, чому ви запитуєте, але так, звичайно ...
Стюі Гріффін

Відповіді:


13

V , 26 байт

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

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

Це дуже дивне і хакітне рішення, оскільки V майже не має поняття чисел. Вводиться у такому форматі:

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

З проміжком на кожному рядку.

Hexdump:

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

Пояснення:

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)

Якщо це не робить зрозумілішим, ось приклади буфера під час різних етапів, через які цикл проходить:

Етап 1 ( |курсор)

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

Етап 2:

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

Етап 3:

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

Етап 4:

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

5 етап:

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

Етап 6:

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

Етап 7:

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

Повернутися до етапу 1:

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



7

Математика, 25 байт

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

Бере два входи mі nта повертає 1-базисні індекси nв m.


6

Сітківка , 32 31 30 байт

1 байт збережено завдяки Kritixi Lithos та 1 байт завдяки Мартину Ендеру

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

Використовує 0-індексацію. Вхід має пробіл у кожному рядку.

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

Пояснення

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

Тут ми замінюємо кожне число на першому рядку на кількість чисел перед тим самим числом у другому рядку.

G1`

Потім ми видаляємо другий рядок, залишаючи лише новий перший рядок як вихідний.



5

C #, 32 байти

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

Це код як лямбда-вираз, тому він повинен бути дійсним.

Рішення має індекс на основі 0. Я думаю, що це досить важко вперед, як це працює - він просто бере пункти n і вибирає індекси елементів у m.



4

Haskell , 32 байти

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

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

Інші спроби:

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

3

k, 1

Це вбудований оператор kі використовує нульову індексацію.

?

Приклад:

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



2

JavaScript (ES6), 28 байт

Займає масиви в синтаксис currying (n)(m). 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])))



2

Japt , 4 байти

m!bV

Перевірте це в Інтернеті

Пояснення

Тут мало що пояснювати, але це демонструє цікаву особливість Japt. Зазвичай ви передаєте функцію m, як-от так:

mX{VbX}

Це в основному U.map(X => V.indexOf(X))( Uнеявне). Однак, коли ви просто виконуєте одну операцію між двома значеннями ( bтут, на Vі X), ви можете просто дати оператору та інше значення, і Japt зробить функцію з нього. Це означає, що mX{X+2}можна в гольф m+2.

Однак це не працює, коли значення знаходяться в неправильному порядку ( mbVскорочується mX{XbV}). Щоб обійти це, ви можете додати знак оклику оператору, який говорить Япту поміняти операнди. Це коштує додатковий байт, але це все-таки на пару байт коротше, ніж альтернатива. А тепер ви знаєте трохи більше про Japt.


2

MATL , 2 байти

&m

Для цього використовується 1-індексація. Спробуйте в Інтернеті!

Пояснення

Метафункція &вказує на те, що наступна функція використовуватиме (специфічний для функції) вторинний стандарт у специфікації / виходу. Для функції m( ismember) &вказує, що буде вироблятися її другий вихід. Він містить індекс (першого виникнення) кожного запису першого входу на другому вході.


2

Хаскелл, 34 байти

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

Приклад використання: [5,3,4,9,7,5,7] # [3,4,5,7,9]->[3,1,2,5,4,3,4]

Вбудований elemIndexв Data.Listі , отже , більше , ніж версія вище. Зовнішня петля проходить через, nа внутрішня - через пари, (i,e)де iзнаходиться індекс eв m. Зберігайте, iде eдорівнює поточному елементу n.


2

R, 20 5 байт

1-індексований; match- це вбудована функція, яка знаходить показники на другому вході елементів першого, тобто match(n,m)дає бажану відповідь

match

завдяки @flodel за вказівку, що повернення функції цілком прийнятне як відповідь!

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


2
Я думаю match(5 байт) одне було б прийнятним рішенням.
флодель

ви правильні, оновлені.
Джузеппе




1

Haskell, 43 байти

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)


1

Perl 5, 38 34 байт

4 байти збережено завдяки Dada

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

1-індексований. Приймає списки m і n як єдиний список, як f(@m,@n). Це x0лише для того, щоб не починати вихід 1,2,3,4,5і т.д.


Гарна відповідь. Зауважте, що анонімні функції дозволені, тому sub{...}ви можете заощадити 2 байти. Також ви можете використовувати x0замість того, &&()щоб зберегти ще два байти.
Дада

1

PHP, 56 байт

Інтернет-версії

0 Індексація

вихід у вигляді рядка

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

PHP, 65 байт

Вивести як масив

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

PHP, 78 байт

обхід с array_map

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

для не унікальних масивів замінити на array_flip($_GET[1])[$v] array_search($v,$_GET[1])



0

Java 7, 80 байт

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

0-індексований

Пояснення:

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

Код тесту:

Спробуйте тут.

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));
  }
}

Вихід:

[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]
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.