Снукер забил

16

Я смотрел чемпионат мира по снукеру, и это заставило меня задуматься ..

Снукер забил

В игре в снукер есть определенные правила, которых вы также должны придерживаться:

  • Когда на столе есть красные шары, во время своего хода вы должны сначала забрать красный шар
  • После того, как вы бросили каждый красный шар, вы должны забрать цветной (не красный) шар (затем цветной горшок затем ставится на стол)
  • После того, как все красные шары подняты (их 15), вы можете сначала выбрать цветной шар, а затем начать с наименьшего забитого мяча и продвинуться до самого высокого забивающего мяча (они не заменяются)
  • Не пот в любой точке заканчивается ваш ход.
  • Очки за мяч
    • Красный шар: 1 очко
    • Желтый шар: 2 очка
    • Зеленый шар: 3 очка
    • Коричневый шар: 4 очка
    • Синий шар: 5 баллов
    • Розовый шар: 6 очков
    • Черный шар: 7 очков

Вопрос

Вы начинаете со стола, в котором все шары по-прежнему на нем - 15 красных и по одному из всех других цветных шаров - и после первого хода вы получаете очки игрока в снукере, как они могли этого добиться? Гол?

Вводом будет счет от 1 до 147. Вы можете выбрать, является ли оно целым числом или строкой. Выходными данными должны быть различные комбинации количества раз, когда вы забили каждый мяч.

Тестовые случаи:

Input: 4
Output: 
1r 1g
2r 1y
Input: 25
Output:
4r 3b
5r 2b 1br 1y
5r 2b 2g
...
9r 8y

Правила:

  • Вы можете выбрать, выводить ли вы возможности, разделенные новой строкой или каким-либо разделителем (/ ,; | \ или другими, которые мне не хватает)

Это Codegolf, поэтому выигрывает самый короткий код.

Michthan
источник
Можно ли вывести в виде списка массивов?
Утренняя монахиня
1
Относительно вывода массива: количество шаров, упорядоченных по счету, однозначно, так что, возможно, "5r 3b 2g"можно было бы вывести как [5,0,2,0,3,0,0](при условии, что это соответствует)?
Джонатан Аллан
2
Вы используете bдля коричневого и blдля синего; так bkпо черному? Можем ли мы использовать n, eи k(последние буквы) для этих трех? Как насчет dlerunaидентификации всех восьми цветов (3-я буква каждого)?
Джонатан Аллан
1
@ Shaggy, если вы используете указание цвета, например, dleruna или другое, нет. Если вы просто используете массив типа [5 0 0 4 1 0 0], то они должны быть отсортированы от низкого к высокому.
Михтан
1
Просто для наглядности, вот (удивительный) пример 147 перерыва Ронни «Ракета» О'Салливана.
Arnauld

Ответы:

6

Желе , 66 байт

L⁼30µÐfµ7Ḋ;\¤;€Ṣ€µ€;/
ċ1<⁴µÐfµ;Ç
7Ḋœċ⁴Ḷ¤;/L€;$€;@þ2B¤;/ḟ€0ÇS⁼¥Ðf⁸G

Ну, это слишком медленно для TIO сейчас!
... так вот паста из 2636 способов сделать ровно 100 произведенных в автономном режиме.
... и вот версия, которая будет работать там только с шестью красными (максимальный перерыв = 75)

Печатает сетку чисел, каждая строка представляет собой список значений шариков, разделенных пробелами (например, три красных и два зеленых будут в строке 1 1 1 3 3).


Для версии с группировкой значений, которая печатает строки отсчетов вместе с полными именами шаров в 102 байта:

ŒrÑ€
Ṫ;ị“¡^³ṗ⁼¬wḌ⁼ø÷OẏK¦ẆP»Ḳ¤$K
L⁼30µÐfµ7Ḋ;\¤;€Ṣ€µ€;/
ċ1<⁴µÐfµ;Ç
7Ḋœċ⁴Ḷ¤;/L€;$€;@þ2B¤;/ḟ€0ÇS⁼¥Ðf⁸Ñ€K€Y

Как?

L⁼30µÐfµ7Ḋ;\¤;€Ṣ€µ€;/ - Link 1, create post-red-ball games: list of all pre-yellow-ball-games
    µÐf               - filter keep if:
L⁼30                  -   length equals 30 (games that get on to the yellow)
       µ         µ€   - for €ach sequence leading to the yellow:
            ¤         -   nilad followed by link(s) as a nilad:
        7Ḋ            -     7 dequeued  = [2,3,4,5,6,7]
          ;\          -     ;\ cumulative reduce with concatenation  = [[2],[2,3],[2,3,4],...]
             ;€       - concatenate the sequence with €ach of those
               Ṣ€     - sort each one
                   ;/ - reduce with concatenation (flatten by one)

ċ1<⁴µÐfµ;Ç - Link 2, filter bogus entries created and append post-yellow-ball games: list of pre-yellow-ball games (along with the bogus ones with 16 reds potted)
    µÐf    - filter keep if:
ċ1         -   count ones
   ⁴       -   literal 16
  <        -   less than?
       µ   - monadic chain separation
         Ç - call the last link (1) as a monad
        ;  - concatenate

7Ḋœċ⁴Ḷ¤;/L€;$€;@þ2B¤;/ḟ€0ÇS⁼¥Ðf⁸G - Main link: score
7Ḋ                                - 7 dequeued = [2,3,4,5,6,7]
      ¤                           - nilad followed by link(s) as a nilad:
     ⁴                            -   literal 16
    Ḷ                             -   lowered range = [0,1,2,...,15]
  œċ                              - combinations with replacement (every possible colour-ball selection that goes with the red pots)
       ;/                         - reduce with concatenation (flatten by one)
            $€                    - last two links as a monad for €ach:
         L€                       -   length of €ach (number of coloured balls potted)
           ;                      -   concatenate
                   ¤              - nilad followed by link(s) as a nilad:
                 2B               -   2 in binary = [1,0]
                þ                 - outer product with:
              ;@                  -   concatenation with reversed @rguments
                    ;/            - reduce with concatenation (flatten by one)
                      ḟ€0         - filter discard zeros from €ach
                         Ç        - call the last link (2) as a monad
                             Ðf   - filter keep:
                            ¥  ⁸  -   last two links as a dyad, with score on the right
                          S⁼      -     sum(ball values) is equal to score?
                                G - format as a grid
                                  - implicit print
Джонатан Аллан
источник
Это хорошо работает для всех случаев, которые я пробовал. Только в некоторых случаях последний код дает начальные нули.
Миштхан
Ах да, они должны были быть отфильтрованы ... Исправлено.
Джонатан Аллан
Ваш вывод для 53 однозначен, как я уже говорил, но я все еще сомневаюсь, что он читается для всех ..
Michthan
Это намного лучше в сетке. Если в ближайшие несколько дней не будет более коротких ответов, я приму ваш ответ!
Миштхан
Хм. Я получаю 2636 комбинаций перерыва века. Так что вы или я не прав ...
Arnauld
4

JavaScript (ES7), 188 180 178 байт

Возвращает массив массивов (отсортированных от красного до черного).

n=>[...Array(17**6)].map((_,x)=>[2,3,4,5,6,p=7].map(v=>(k=a[++j]=x%17|0,x/=17,t+=k,p+=!!(y=y&&k),s-=k*v),y=s=n,a=[j=t=0])&&(s==15|s>=t)&s<16&s<t+2&t<9+p&&(a[0]=s,a)).filter(a=>a)

комментарии

Примечание . Эта версия не включает в себя последнюю оптимизацию p(теперь инициализированную до 7), что затрудняет понимание логики.

n =>                              // given a target score n:
  [...Array(17**6)].map((_, x) => // for each x in [0 .. 17^6 - 1]:
    [2, 3, 4, 5, 6, 7].map(v =>   //   for each v in [2 .. 7] (yellow to black):
      ( k = a[++j] = x % 17 | 0,  //     k = a[j] = number of colored balls of value v
        x /= 17,                  //     update x to extract the next value
        t += k,                   //     update t = total number of colored balls
        p += !!(                  //     update p = number of consecutive colors that were
          y = y && k              //     potted at least once, using y = flag that is zeroed
        ),                        //     as soon as a color is not potted at all
        s -= k * v ),             //     subtract k * v from the current score s
      y = s = n,                  //     initialize y and s
      a = [j = t = p = 0]         //     initialize a, j (pointer in a), t and p
    )                             //   at this point, s is the alleged number of red balls
    &&                            //   this combination is valid if we have:
      (s == 15 | s >= t) &        //     - 15 red balls or more red balls than colored ones
      s < 16 &                    //     - no more than 15 red balls
      s < t + 2 &                 //     - at most one more red ball than colored ones
      t < 16 + p                  //     - no more than 15 + p colored balls
    &&                            //   if valid:
      (a[0] = s, a)               //     update the combination with red balls and return it
  ).filter(a => a)                // end of outer map(): filter out invalid entries

Пример вывода

Ниже приведен вывод для n = 140:

//  R   Y  G  Br Bl P  Bk 
[ [ 15, 1, 1, 1, 1, 8, 9  ],
  [ 15, 1, 1, 1, 2, 6, 10 ],
  [ 15, 1, 1, 1, 3, 4, 11 ],
  [ 15, 1, 1, 2, 1, 5, 11 ],
  [ 15, 1, 1, 1, 4, 2, 12 ],
  [ 15, 1, 1, 2, 2, 3, 12 ],
  [ 15, 1, 2, 1, 1, 4, 12 ],
  [ 15, 1, 1, 2, 3, 1, 13 ],
  [ 15, 1, 1, 3, 1, 2, 13 ],
  [ 15, 1, 2, 1, 2, 2, 13 ],
  [ 15, 2, 1, 1, 1, 3, 13 ],
  [ 15, 1, 2, 2, 1, 1, 14 ],
  [ 15, 2, 1, 1, 2, 1, 14 ],
  [ 15, 1, 1, 1, 1, 1, 15 ] ]

демонстрация

Это слишком медленно для фрагмента. Вы можете попробовать это здесь вместо этого. (Вы можете получить одно или два неотзывчивых предупреждения скрипта , но это должно в конечном итоге завершиться.)

Arnauld
источник