Взуття для морських коней


30

Морські коні, звичайно, потребують взуття. Однак морському коні, маючи лише один хвіст, потрібна лише одна взуття. На жаль, взуття буває лише парами. Гроші для уряду з морськими конячками є тяжкими, тому їх потрібно купувати якомога менше пар. Кожен морський коник має розмір взуття x, де x - додатне ціле число. Однак морський коник може носити взуття розміром x - 1 або x + 1, якщо потрібно.

Ваше завдання - вивести мінімальну кількість пар, яку повинен придбати уряд морських коней, щоб надіти взуття на всіх своїх морських коней.

Ви можете взяти вхід, як завгодно, стандартні лазівки тощо.

Оскільки це , виграє найкоротший код у байтах.

Тестові справи

2 4 6 6 8 14 ->        4
2 1 3 1 1 ->           3
4 1 4 9 1 8 9 1 8 4 -> 6
1 2 3 5 7 8 10 12 ->   4

Це можна зробити тривіально, відсортувавши масив та переглянувши його, але я хотів би побачити щось креативне (це не має жодного стосунку до фактичного оцінювання, я просто думаю, що було б цікаво побачити інший підхід)
сфальсифікований

1
Я не бачу, як це можна зробити тривіально ...
Leaky Nun

5
@ bushdid911 Я думаю, я не можу пояснити, як працює Jelly у коментарі
Leaky Nun

1
@CodyGray Ви можете мати пару розміром 3, яка охоплює 2 і 4.
Zgarb

2
Потенційний заголовок редагувати: Морські підкови
CraigR8806

Відповіді:


5

05AB1E , 13 байт

Використовується підхід, описаний у коментарях.

{¥3‹J0¡€gÌ2÷O

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

Пояснення

{¥3‹J0¡€gÌ2÷O   Argument l
{               Sort l
 ¥              Push deltas
  3‹            Map to lower than 3 (1 for true, 0 for false)
    J0¡         Join and split on 0
       €g       Map to length
         Ì      Each + 2
          2÷    Integer division by 2
            O   Sum

8

Лушпиння , 15 14 байт

Γ0(→₀?tI↑<+3)O

Використовує жадібний алгоритм: сортуйте та з'єднайте зліва. Спробуйте в Інтернеті!

Дякуємо Лео за збереження 1 байта.

Пояснення

Це перша відповідь Husk, яка використовує Γфункцію для узгодження шаблону зі списком. У цьому випадку використання, якщо aє значенням і gє функцією, то Γagвідповідає функціїf визначеній фрагментом Haskell

f [] = a
f (x:xs) = g x xs

Я визначаю базовий випадок як a = 0 і

g x xs = 1 + line0 (if head xs < x+3 then tail xs else xs)

де line0посилається на весь рядок. У коді Husk xі xsє неявні аргументи функції лямбда, і line0є . Список відсортований знову за кожним рекурсивним дзвінком, але це не має значення для проблеми з гольфом.

Γ0(→₀?tI↑<+3)O
             O  Sort
Γ               and pattern match
 0              giving 0 for an empty list
  (         )   and applying this function to a non-empty list:
          +3     Add 3 to first argument (x),
         <       make a "test function" for being less than that,
        ↑        take values from second argument (xs) while they pass the test.
     ?           If that prefix is nonempty (next value can be paired),
      t          take tail of xs,
       I         otherwise take xs as is.
    ₀            Apply the main function (line0) to this list
   →             and add 1 for the singleton/pair we just processed.

Усі ці люди, які використовують свої власні мови, змушують мене створити свою власну. Спершу я повинен придумати ім’я: P
сфальсифікований

5

Python 3 , 69 66 60 байт

9 байт завдяки xnor.

f=lambda a:a[1:a.sort()]and-~f(a[1+(a[1]-a[0]<3):])or len(a)

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


Я думаю, ти можеш зробити a.sort().
xnor

@xnor зроблено, спасибі
Leaky Nun

Сортування можна вставити в lambda:f=lambda a:a[1:a.sort()]and-~f(a[1+(a[1]-a[0]<3):])or len(a)
xnor

or[]<aщоб зберегти 3 байти
Феліпе Нарді Батіста

4

Желе , 20 18 байт

ṢLµIḢ<3+2⁸ṫß‘µLỊ$?

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

Вилка моєї відповіді Python .


-4 байти: IḢ<3+2⁸ṫß‘µLḊ?(в основному я не бачу жодних причин робити раніше L, і я повернусь, []якщо список, якщо довжина 1 або 0, і тоді я можу видалити µз нього LµḊ?)
Ерік Outgolfer

Але ви ніде не розбиралися ...
Leaky Nun

Тепер я трохи розгублений tbf ... Я думаю, що ваш намір дещо інший, ніж те, що насправді робить ваш код? Можливо, ви захочете додати до мого гольфу, якщо я правильно розумію.
Erik the Outgolfer

Щось химерне з вашим сортом. [1, 1, 1, 1, 4, 4, 4, 8, 8, 9, 9] працює, але [4,1,4,9,1,8,9,1,8,4,1] не ' т.
сфальсифікований

@ bushdid911 Вони обоє працюють. Не могли б ви продемонструвати?
Leaky Nun

4

Python 2 , 49 байт

f=lambda a:a>[a.sort()]and-~f(a[[3+a.pop(0)]>a:])

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

На основі рекурсивного рішення Leaky Nun .


Python 2 , 59 байт

p=c=0
for x in sorted(input()):c+=x>p;p=(x>p)*(x+2)
print c

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

Змінюється за розмірами xу відсортованому порядку. Запам'ятовує верхній поріг pпоточного розміру до парного з попереднім. Якщо так ( x>p), відновіть поріг, щоб 0унеможливити спарювання наступного. Якщо ні, збільште кількість вихідних даних cі встановіть наступний поріг pнаx+2 .

Новий поріг p=(x>p)*(x+2)- роздутий вираз. Я хотів би знайти спосіб її скоротити.


2

C #, 111 108 137 102 байт

Це ніколи не виграє, але я хотів вирішити вправу все одно:

Array.Sort(a);var c=0;for(var i=0;i<a.Length;i++){c++;i+=a.Length-i>1&&a[i+1]-a[i]<3?1:0;}Console.WriteLine(c);

Завдяки коментарю @grabthefish, я зміг нажати ще декілька байтів:

Array.Sort(a);int c=0,i=0;for(;i<a.Length;i++){c++;i+=a.Length-i>1&&a[i+1]-a[i‌​]<3?1:0;}Console.Wri‌​teLine(c);

Дотримуючись спеціальних правил C # PC & G:

class P{static void Main(){Array.Sort(a);int c=0,i=0;for(;i<a.Length;i++){c++;i+=a.Length-i>1&&a[i+1]-a[i]<3?1:0;}Console.WriteLine(c);}}

Використання лямбда-функції:

a=>{System.Array.Sort(a);int c=0,i=0;for(;i<a.Length;c++)i+=a.Length-i>1&&a[i+1]-a[i]<3?2:1;return c;}

Коментарі не для розширеного обговорення; ця розмова переміщена до чату .
Денніс

Дякую за те, що підтримуєте прогрес у відповідях - це так само цікаво, як і остаточна відповідь.
Criggie

2

Perl, 113 байт

say sub{for(1..$#_){$x{$i}++;$i++if$_[$_]-$_[$_-1]>2}$x{$i}++;$-+=$_/2+$_%2for values%x;$-}->(sort{$a<=>$b}@ARGV)

Бере список аргументів з командного рядка (as @ARGV), друкує до STDOUTза замовчуванням.

У Seahorseville ...

А Околиця є послідовність сусідніх розмірів взутті. При сортуванні кожен морський коник має безпосередніх сусідів, які можуть мати однаковий розмір взуття. По сусідству може бути кілька сусідів, і жоден сусід не може відрізнятися за величиною більш ніж на два:

напр 3 3 4 5 5 6 є єдине сусідство, як є 2 4 6 6, і1 2 3 5 7 8 10 12

наприклад, 1 1 1 4 5 6містить два мікрорайони:1 1 1 і 4 5 6.

Основи алгоритму

Є два типи сусідства:

  • Рівномірні розміри

    Для цього n/2пар завжди достатньо:

    наприклад , 3 3 4 5 5 6потрібно три пари для 3 3, 4 5і5 6

  • Непарного розміру

    Для цього ceil(n/2)пар завжди достатньо:

    наприклад , 12 13 13 14 15потрібно три пари для 12 13, 13 14і в 15поодинці.

Невикольований код для перевірки алгоритму

sub pairs {
    @_ = sort { $a <=> $b } @_;
    my @hood;
    my $i = 0;
    for (1..$#_) {
        push @{$hood[$i]}, $_[$_-1];
        $i++ if $_[$_]-$_[$_-1]>2
    }
    push @{$hood[$i]}, $_[$#_];
    my $pairs;
    $pairs += int(@{$hood[$_]} / 2) + @{$hood[$_]} % 2 for 0..$#hood;
    return "$pairs : @{[map qq([@$_]), @hood]}\n";
}

Зразкові результати

(Район укладений [ ] )

4 : [2 4 6 6 8] [14]
3 : [1 1 1 2 3]
6 : [1 1 1] [4 4 4] [8 8 9 9]
4 : [1 2 3 5 7 8 10 12]
17 : [1 2 3] [6 8 9 11 13 13 15 17 19 20 21] [27 28 29 30 32 33 35 35] [38 38 40] [43 45 45 46] [49]
18 : [3 3 3] [8 10 11 11 11 12 14] [18] [21 22 23] [29] [32 33 34 34 34 35 37 38 39 41] [44 46 48 49 49]
18 : [1 2 3] [6] [9] [12 13 15 17 18 19 20 21 21 23 24 25 25] [35 36] [40 41 41 41 43 45 46 46 46] [49]
16 : [1 3] [6 6 6 6] [11 12 14 14 15 17 19 20 20 21 21 22] [25 25 27 29 31 32 33] [38 39] [44 45] [49]
16 : [2 4] [7 7 8 10 12 13 15 16] [22 22 24 24] [27 29 31 31 33 34] [37 38 39] [42 43 43 44 45 46 47]
17 : [2 4 5 6 7] [11 11 13 13 14 15 16 17 17 17 19] [29] [34 35 36] [39 39 41 41 41 42 44 46] [49 49]
18 : [3 4 5 7 7] [10 10 12 12 12 14 15 15 17 18] [21] [24 24] [28] [32] [39 40 41 42 43 44 44] [47 47] [50]
16 : [2 4] [7 7 8 8] [11 11] [14 16 17 17 18 19] [22 24 26 26] [30 31 33 34 34 35] [38 38 39] [42 43] [50]
16 : [1 3 4 5] [11 11] [15 15 17 18 19 21 22 23 23 25 27 27 27 27 28 29 30 30] [33 34] [41 41] [45] [48]
17 : [2 2 3 4 6 6 7] [10 10] [13 14 15 16 17 19] [23 25] [28 30 31 32 33 34 36 37 38] [42] [48 49 50]
17 : [2] [7 9 9 9 9 10 10 12] [16 16] [19 21 21 22 24] [27 27 27] [36 36 36 37 39 39 40 40 40 41] [46]
18 : [1] [5 6 6 8] [11 11 12] [19 19 20 21 22 24 26 26] [29 30 31 32 34 35 35] [38] [42] [45] [48 48 49 49]
16 : [2 4 4 6] [11 12 13 13 13] [21 21 21 23] [30 31 31 33 35] [41 41 41 43 45 46 47 48 48 49 49 50]
16 : [2 2] [8 10 12] [15 15 15 15 16 16] [19 20] [23 24] [28 28 29] [32 34 36 36 36 37 39 41] [44 45 47 48]
17 : [3 3] [6] [9 10 11] [17 18] [21 23 23] [27 28 29 29 30 31 31 33] [37 37 39 39 39 40] [43 44] [47 48 49]
17 : [4] [7 9 10 10] [14 14 14] [17] [21] [25 25 27 27 28 30] [33 35 37 37 38 40 41 43 44 45 47 48 49 50]
18 : [3 4 5 6 7] [10 11 12 12 14 15 16 17] [20] [23 24 25 25 26 26] [31] [35] [38 40 41 42] [45 46 47] [50]
17 : [1 3] [8 10] [16 16 18 19 20 20] [23 23] [26] [30 31 33 34 35] [39 39 39 40 41 42 43] [46 46 47 47 49]
18 : [2 4 4 4 4 6 7 8 8 10 10] [13] [16 17] [20 22 23 25 25] [29 29 29] [33] [39 40 42] [48 48 49 49]
16 : [1 1 3 4] [7 8 10 10] [18 18 20 21] [24 25 26 27 29 31 33 33 34 34] [37 37 39] [45 46 48 49 49]
17 : [1] [4 4] [7 9 9 11 12] [15 16 17 17 18 19 21 21 21 22 23] [27 28 30 31] [37 39] [42] [48 49 49 50]
17 : [3 4 6 7 7 8 9 10 10 11 13 14 14] [21 21 23] [26 27] [31 32] [35 36] [39 40 41 41 41] [44 44] [49]
16 : [1] [4 6 6 8 10 12 13 15] [20 20 21 21] [29 29 30] [34 36 36 37 37 38 38 40] [44 45 46 47 47 48]
17 : [3 4 4 6] [12 14 15 16 17] [20 21 22 22 22 23 24 26 26] [29 30 32] [35 37 37 37 38 39 41 42] [48]
19 : [1] [5] [8 9] [14 14 14 16 16 17 17 17 17] [21] [24 24 24] [30] [34 35 36 37 39 40 40] [45 46 46 47 48]

1

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

Length@Flatten[Partition[#,UpTo@2]&/@Split[Sort@#,Abs[#-#2]<3&],1]&

Спробуйте в пісочниці Wolfram .


Будь-яким способом ми можемо протестувати? Як річ Вольфрам?
LiefdeWen

@LiefdeWen Ви можете спробувати онлайн! з математики. Mathics не підтримує всі функції мови Wolfram, але ті, що використовуються в цьому записі, реалізовані, тому або Mathics зламана, або це рішення недійсне.
Павло

Він працює на sandbox.open.wolframcloud.com , тому проблема в стороні
Mathics

1
@Phoenix не думаю, що Mathics підтримуєUpTo
мартін

0

Perl, 103 байти

say sub{for(1..$#_+1){$x{$i}++;$i++if$_[$_]-$_[$_-1]>2}@_/2+.5*grep$_%2,values%x}->(sort{$a<=>$b}@ARGV)

Бере список аргументів з командного рядка (as @ARGV), друкує до STDOUTза замовчуванням.

Це альтернативний підхід, який базується на наступних відносинах:

Minimum pairs = ( Population size + # Odd neighbourhoods ) / 2

(Дивіться цю відповідь, як визначається сусідство )


0

Javascript, 67 байт

a=>(a=a.sort((a,b)=>a-b)).filter((n,i)=>m=!m|n-a[i-1]>2,m=0).length

Приклад фрагмента коду:

f=
a=>(a=a.sort((a,b)=>a-b)).filter((n,i)=>m=!m|n-a[i-1]>2,m=0).length

v=[[2,4,6,6,8,14],[2,1,3,1,1],[4,1,4,9,1,8,9,1,8,4],[1,2,3,5,7,8,10,12]]
for(k=0;k<4;k++)
  console.log(`f([${v[k]}])=${f(v[k])}`)

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