Переключение силы тяжести

14

Вызов

Вам предоставляется представление символов ASCII на плоскости в качестве ввода любым разумным способом. Это будет содержать только:

  • [a-z]представляющие подвижные персонажи. Каждая буква появится на доске не более одного раза.
  • # представляющие неподвижные стены
  • . представляет пустое пространство

Например:

abcdef.gh#..
.......ij.#.
#..#.......#
...#.#...###
.#.......#q#
.........###

Вам также дают строку, представляющую изменения в гравитации. Это будет содержать только:

  • > представляет изменение в правой гравитации
  • < представляющий изменение в левой гравитации
  • ^ представляет изменение в сторону увеличения силы тяжести
  • v представляющий изменение в нисходящей гравитации

Например:

v>^

Ваша программа должна симулировать каждое изменение гравитации последовательно, пока все персонажи не перестанут двигаться (они ударяются о стену или другого персонажа). Символы, которые «падают с края карты», навсегда удаляются, и персонажи могут «укладываться» друг на друга.

В этом примере, в начале есть вниз сила тяжести ( v), так что c, e, g, h, i, и jупасть в нижней части карты. Все остальные персонажи скользят вниз до удара о стену, оставляя карту так:

.........#..
a..d......#.
#..#.f.....#
.b.#.#...###
.#.......#q#
.........###

Затем мы переходим к правой гравитации ( >), что оставляет нас с этим: Обратите внимание, как aстеки рядом с d.

.........#..
........ad#.
#..#......f#
..b#.#...###
.#.......#q#
.........###

Наконец, мы моделируем восходящую гравитацию ( ^), во время которой aи bпадают с карты.

.........#..
.........d#.
#..#......f#
...#.#...###
.#.......#q#
.........###

Ваша задача - вывести оставшиеся символы после гравитационных сдвигов. Они могут быть даны в любом порядке. Для этого примера вы можете вывести любую перестановку dfq.

Testcases

Для следующей карты:

abcde
.....
##.##
v   =  abde
v>  =  <nothing>

Для следующей карты:

######
#....#
abcdef
#.gh..
######
>   = <nothing>
<   = gh
^>  = bcde
v<  = bghef
jrich
источник
Как вводится информация? Список строк? Аргумент функции? STDIN?
Утренняя монахиня
@KennyLau Все эти варианты в порядке. Ввод и вывод может быть любым разумным для вашего языка.
jrich
Несколько связано.
Мартин Эндер

Ответы:

4

JavaScript (ES6), 251 233 байта

(m,d,r=`replace`)=>[...d].map(c=>[...`<^>v`].map(d=>m=[...(m=(c==d?m[r](/[.\w]+/g,s=>s[r](/\./g,``)+s[r](/\w/g,``))[r](/^\w+/gm,s=>s[r](/./g,`.`)):m).split`
`)[0]].map((_,i)=>m.map(s=>s[i]).join``).reverse().join`
`))&&m[r](/\W/g,``)

Изменить: Сохранено 18 байт благодаря @WashingtonGuedes.

Работает, поворачивая входную сетку четыре раза для каждого символа направления, но в направлении, где символ направления соответствует символу цикла, мы делаем левую гравитацию. псевдокод:

function slideleft(map) {
    map = map.replace(/[.\w+]/g, match=>movedotstoend(match));
    map = map.replace(/^\w+/gm, match=>changetodots(match));
}
function rotate(map) {
    return joinrows(reverse([for each (column of rows(map)[0])
            joinrow([for each (row of rows(map)) row[column]])
           ]));
}
function gravity(map, directions) {
    for each (direction of directions) {
        for each (angle of '<^>v') {
            if (direction == angle) map = slideleft(map);
            map = rotate(map);
        }
    }
    return letters(map);
}
Нил
источник
3

JavaScript (ES6), 199

Тот же алгоритм ответа @ Нейла. Сетка вращается четыре раза для каждого символа направления, когда в правильном положении гравитационный сдвиг влево применяется к каждому ряду.

x=>y=>(x=>{for(d of y){R='';for(e of'^>v<')x=[...x[0]].map((c,i)=>e!=d?x.map(r=>r[i]).join``:x.map(r=>(c=r[i])<'.'?(q+=p+c,p=''):c>'.'&&q?(q+=c,R+=c):p+='.',q=p='')&&q+p).reverse();}})(x.split`
`)||R

F=x=>y=>(x=>{for(d of y){R='';for(e of'^>v<')x=[...x[0]].map((c,i)=>e!=d?x.map(r=>r[i]).join``:x.map(r=>(c=r[i])<'.'?(q+=p+c,p=''):c>'.'&&q?(q+=c,R+=c):p+='.',q=p='')&&q+p).reverse();}})(x.split`
`)||R

// Less golfed

U=(x,y)=>
{
  x = x.split`\n`;
  for(d of y)
  {
    R = '';
    for(e of '^>v<')
      x = [...x[0]].map( 
        (c,i) => e != d
        ? x.map( r => r[i] ).join`` // basic rotation
        : x.map( // rotation with gravity shift
          r=> (c=r[i])<'.' ? (q+=p+c,p='') : c>'.'&&q?(q+=c,R+=c) : p+='.', q=p=''
        ) && q+p
      ).reverse();
  }
  return R
}

console.log=x=>O.textContent+=x+'\n'

;[
  ['abcdef.gh#..\n.......ij.#.\n#..#.......#\n...#.#...###\n.#.......#q#\n.........###',
   [['v>^','dfq']]
  ],
  ['abcde\n.....\n##.##',[['v','abde'],['v>','']]],
  ['######\n#....#\nabcdef\n#.gh..\n######',[['>',''],['<','gh'],['^>','bcde'],['v<','befgh']]]
].forEach(t => {
  var i=t[0]
  console.log(i)
  t[1].forEach(([d,k])=>{
    var r=F(i)(d),ok=[...r].sort().join``==k
    console.log((ok?'OK ':'KO ')+d+' : '+r+(ok?'':' (expected '+k+')'))
  })
  console.log('')
})
<pre id=O></pre>

edc65
источник
2

Pyth, 143 байта

(Нам действительно нужно столько байтов?)

JhQKeQMe.u:N+"\."H+H"."G;DybVkI}NG=gkN;D'bVlJ=k@JNykVkI}HG=:kH\.).?B)=XJNk;VKIqN\<'J)IqN\v=C_J'J=_CJ)IqN\>=C_CJ'J=C_CJ)IqN\^=CJ'J=CJ;VJVNI}HGpH

Попробуйте онлайн!

Как это устроено

Мы определяем функцию, leftкоторая выполняет левую гравитацию.

Затем другие направления реализуются путём связывания с массивом, так что желаемое направление влево, а затем делайте left.

Алгоритм leftздесь:

  • Сделайте следующее до идемпотента:
  • Заменить ".X"на "X.", где Xпредставляет букву.

Вся программа разделена на следующие 6 разделов:

JhQKeQ
Me.u:N+"\."H+H"."G;
DybVkI}NG=gkN;
D'bVlJ=k@JNykVkI}HG=:kH\.).?B)=XJNk;
VKIqN\<'J)IqN\v=C_J'J=_CJ)IqN\>=C_CJ'J=C_CJ)IqN\^=CJ'J=CJ;
VJVNI}HGpH

Первый раздел

JhQKeQ     Q auto-initialized to evaluate(input())
JhQ        J = Q[0]
   KeQ     K = Q[len(Q)-1]

Второй раздел

Me.u:N+"\."H+H"."G;   @memoized
M                 ;   def g(G,H):
  .u             G      repeat_until_idempotent(start:G, as N):
    :Nxxxxxxyyyyy         return N.replace(xxxxxx,yyyyy)
      +"\."H                               "\."+H
            +H"."                                 H+"."

Третий раздел

DybVkI}NG=gkN;    @memoized
Dyb          ;    def y(b):
   Vk               for N in k:     --TAKES GLOBAL VARIABLE k
     I}NG             if N in G:    --G pre-initialized to "abcde...z"
         =gkN           k = g(k,N)

Четвертый раздел

D'bVlJ=k@JNykVkI}HG=:kH\.).?B)=XJNk;  @memoized
D'b                                ;  def single_quote(b):
   VlJ                       )          for N in range(len(J)): --TAKES GLOBAL VARIABLE J
      =k@JN                               k = J[N] --SETS GLOBAL VARIABLE k
           yk                             y(k) --returns nothing, but MODIFIES GLOBAL VARIABLE k
             Vk                           for H in k:
               I}HG      )                  if H in G:
                   =:kH\.                     k = k.replace(H,".")
                          .?                else:
                            B                 break
                              =XJNk     J[N] = k --MODIFIES GLOBAL VARIABLE J

Пятый раздел

VKIqN\<'J)IqN\v=C_J'J=_CJ)IqN\>=C_CJ'J=C_CJ)IqN\^=CJ'J=CJ;
VK                                                       ; for N in K:
  IqN\<  )                                                   if N == '<':
       'J                                                      single-quote(J)
          IqN\v          )                                   if N == 'v':
               =C_J                                            J = transpose(reverse(J))
                   'J                                          single-quote(J)
                     =_CJ                                      J = reverse(transpose(J))
                          IqN\>            )                 if N == '>':
                               =C_CJ                           J = transpose(reverse(transpose(J)))
                                    'J                         single-quote(J)
                                      =C_CJ                    J = transpose(reverse(transpose(J)))
                                            IqN\^            if N == '^':
                                                 =CJ           J = transpose(J)
                                                    'J         single-quote(J)
                                                      =CJ      J = transpose(J)

Шестой раздел

VJVNI}HGpH
VJ           for N in J:
  VN           for H in N:
    I}HG         if H in G: --G = "abc...z"
        pH         print(H)
Дрянная Монахиня
источник
1

Рубин, 306 байт

Анонимная функция. Довольно обходная техника, которая, вероятно, может быть оптимизирована.

->s,d{w=[];x=y=0;m={}
s.chars.map{|c|c>?!?(c<?A?c<?.?w<<[x,y]:0:m[c]=[x,y]
x+=1):(x=0;y+=1)}
d.chars.map{|c|q=[c<?=?-1:c<?A?1:0,c>?a?1:c>?A?-1:0];e=1
(n=m.clone.each{|k,v|z=[v[0]+q[0],v[1]+q[1]]
w.index(z)||m.value?(z)?0:m[k]=z}
m.reject!{|k,v|i,j=v;i<0||i>=x||j<0||j>y}
e=(m!=n ?1:p))while e}
m.keys.join}
Значение чернил
источник