Згорнути ascii-art


12

Виклик

Задавши прямокутну сітку символів для друку ascii у вигляді рядка або за допомогою стандартного вводу, напишіть функцію або програму, яка згортає символи, що не знаходяться з пробілом, на купу внизу.

Правила:

  • Вихід має ті ж розміри і символи, що і вхід.
  • Символ, який не знаходиться в (row a,column b)пробілі, не може містити пробілу ' 'в (a-1, b), (a-1,b-1)або (a-1,b+1)там, де рядки пронумеровані в нижній частині. Це означає, що всі вертикальні палі повинні згортатися набік.
  • Непросторовий персонаж може подорожувати в більшості (initial height - final height)місць ліворуч або праворуч (див. Рис. 1).
  • Ви можете припустити, що в картині є достатньо місця для згортання, аби символи не випадали з екрана.

Малюнок 1: можливі кінцеві місця для символів, @#$показані x,y,zвідповідно.

..............
...@..........
..xxx.........
.xxxxx...#....
xxxxxxx.yyy.$.

Порядок, коли символи згортаються, можна вибирати вільно. Пробіли не в порядку, але нові лінії є.

Це , тому найкоротша відповідь у байтах виграє!

Приклад

                 (__)
                 (oo)
           /------\/
          / |    ||
         *  /\---/\
            ~~   ~~
..."Have you mooed today?"...

Один можливий вихід:

 
 
 
                --(_
           /----|/|(o_)
          /|/~\---~\\/o)
..."Have*you~mooed~today?"...

Просто для уточнення, як падіння персонажів може бути жорстко закодованим, а не випадковим чином генеруватися кожен раз?
ETHproductions

18
Що тобі зробила та корова ?? :(
FlipTack

@ETHproductions це правильно. Мій приклад робить це знизу вгору, зліва направо, але випадковий порядок або щось інше добре, якщо правила дотримуються.
Ангс

@ Flp.Tkc Це лише модель.
Ангс

1
@DestructibleWatermelon якщо персонаж випаде з екрану, це їхня вина, а не ваша.
Ангс

Відповіді:


4

JavaScript (ES6), 100 90 88 байт

f=s=>s==(l=s.search`
`,s=s.replace(eval(`/(\\S)([^]{${l-1},${l+1}}) /`),` $2$1`))?s:f(s)
s=`                 (__)        
                 (oo)        
           /------\\/         
          / |    ||          
         *  /\\---/\\          
            ~~   ~~          
..."Have you mooed today?"...`
console.log(s)
console.log(f(s))

Потрібно, щоб рядок мав принаймні два рядки, а всі рядки підкреслені однаковою довжиною. Виведення для прикладу зображення:

              ( --           
            /|---/|-(o__     
          */~~\---~\|\/o))   
..."Have you/mooed~today?"...

Зауважте, що при спробі переміщення елементів праворуч, якщо це можливо, значення *не потрапляє між Haveі you.

Редагування: заощаджено 10% завдяки @ETHproductions. Збережено ще 2 байти завдяки @DanielIndie.

Сітківка 0,8,2 , 50 байт

+`(?<=(.)*)(\S)(.*¶(?<-1>)?(?>(?<-1>.)*).?) 
 $3$2

Спробуйте в Інтернеті! Дещо інший підхід до моєї відповіді на JavaScript, для цього використовується балансуюча група, щоб відповідати пробілу нижче символу, який не є пробілом; the (?<-1>)?дозволяє пробілу бути одним стовпцем ліворуч, тоді .?як простір може бути одним стовпцем праворуч.

Сітківка , 40 байт

~0L$`.(.*)¶
+s`(\S)(.{$.1,$.&}) ¶ $$2$$1

Спробуйте в Інтернеті! Порт моєї відповіді на JavaScript. 0L$Атомний етап приймає вхідний сигнал і замінює дві довжину на другу лінію , в результаті чого команди , яка фактично виконує заміни, який потім оцінювали на початковому вхід з боку ~стадії з'єднання.


Це чудовий алгоритм! Ви можете замінити \nбуквальним
новим

Крім того, я думаю, ви можете так, l=s.search`\n` щоб зберегти кілька байт.
ETHproductions


@DanielIndie f=Потрібна для рекурсії, але вона все одно економить мені 2 байти, дякую!
Ніл

ви маєте рацію, вибачте: P
DanielIndie

3

Python 2, 298 байт

a=input()
L=len(a);s=' '
a=[list(s*L+l.ljust(L+max(map(len,a))))for l in a]
t=1
while t:
 t=0
 for y in range(L-1):
  for x in range(len(a[y])):
   c=a[y][x];C=a[y+1][x-1:x+2]
   if s!=c and s in C:t=1;a[y][x]=s;a[y+1][[[x+1,x][C[1]==s],x-1][C[0]==s]]=c
for l in map(''.join,a):print l[L:].rstrip()

Вводиться як список рядків (по одному на рядок)

Приклад: Введення:

['                 (__)',
'                 (oo)',
'           /------\/',
'          / |    ||',
'         *  /\---/\ ',
'            ~~   ~~',
'..."Have you mooed today?"...']

Вихід:

              (
            -----/|-(o__
         //|~~\---~\|\/o))
..."Have*you/mooed~today?"...

3

C, 252 байти

e=1,l,c,i,j,p,r,w,a[999];f(){while((i=getchar())>0)a[w++]=i,i<16?l++:0,l?0:c++;while(e)for(i=e=0;i<c;i++)for(j=l;j>=0;j--)e=(r=a[p=j*(c+1)+i]-32?a[r=p+c+1]-32?a[r=p+c]-32?a[r=p+c+2]-32?0:r:r:r:0)?l=a[p],a[p]=a[r],a[r]=l:e;for(i=0;i<w;)putchar(a[i++]);}

Невикористаний код тесту:

#include <stdio.h>

e=1,l,c,i,j,p,r,w,a[999];
f()
{
    // counting lines and columns
    while ((i = getchar())>0)a[w++] = i, i<16 ? l++ : 0, l ? 0 : c++;
    // main shaking loop
    while (e) // repeat while collapsing
        for (i = e = 0; i < c; i++) // columns loop
            for (j = l; j >= 0; j--) // lines loop
                e = ( // remember that collapsing was
                     r = // find place to collapse
                         a[p = j*(c + 1) + i] - 32 ? // if not space
                             a[r = p + c + 1] - 32 ? // if char under the current is not a space
                                 a[r = p + c] - 32 ? // see one position left
                                    a[r = p + c + 2] - 32 ? 0 // then one position right
                                                          : r
                                    : r
                                 : r
                             : 0
                         ) ? // and if place was found
                           l=a[p],a[p]=a[r],a[r]=l // replace values in positions p and r
                           : e;
    //print resulting picture
    for(i=0;i<w;)putchar(a[i++]);
}

int main(void)
{
    int cnt;
    FILE * testf = fopen("caw.txt","w");
    char testd[][31] = {
        "                 (__)        \n",
        "                 (oo)        \n", 
        "           /------\\/         \n", 
        "          / |    ||          \n", 
        "         *  /\\---/\\          \n", 
        "            ~~   ~~          \n", 
        "...\"Have you mooed today ? \"...",
        "" };
    // prepare data for test
    printf("Initial data:\n");
    for(cnt = 0; cnt < 7; cnt++)
    {
        printf("%s", testd[cnt]);
        fprintf(testf, testd[cnt]);
    }
    fclose(testf);
    // redirect standard input
    freopen("caw.txt", "r", stdin);
    printf("\n\nResult:\n");
    // start test
    f();
}

Результат тесту:

введіть тут опис зображення


2

Альгодуо (не конкуруючий)

Введений приклад - вироджений приклад, що використовується.

Налаштування

Біг - гравітація за замовчуванням і підстрибування.

Біг

Вихід - точність може бути відрегульована за допомогою параметрів тертя та щільності об єктів.

Вихідні дані

Algodoo є логічно програмованим .


Чому це неконкуренто? Як правило, конкуренція зарезервована для відповідей мовами, новішими за виклики.
Ad Hoc Hunter Hunter

Хоча Algodoo може використовувати справжню логіку, це моделювання рівносильне викиданню подрібнення роздруківки з входу на підлогу та його фотографуванню. Я не впевнений, що, як програматизувати цей висновок, точно.
wyldstallyns

І здавалося, неправильно сказати "нульова байтова програма! Я перемагаю!"
wyldstallyns

Я підозрюю, що це насправді не нульова байтова відповідь. Ви говорите про налаштування налаштувань, які, здається, є еквівалентом написання коду. Можливо, буде гарною ідеєю відкрити мета-запитання про зарахування Algodoo. Я також не думаю, що немає нічого поганого в наявності програми з нульовим байтом.
Спеціальний мисливець на Гарф

Я відкрию цю мета.
wyldstallyns

1

JavaScript, 286 байт

b=>eval('f=b=>b==null||" "==b;b=b.split`\n`.map(b=>[...b]);a:for(;;){for(c=0;c<b.length-1;c++)for(g=b[c],d=0;d<g.length;d++){h=g[d];if(!f(h)){e=0;f(b[c+1][d])?e=2:f(b[c+1][d-1])?e=1:f(b[c+1][d+1])&&(e=3);if(e){b[c+1][d+e-2]=h;b[c][d]=" ";continue a}}}break}b.map(b=>b.join``).join`\n`')

Приклади

// Here I assume that you've assigned the above function to `fall`
console.log(fall(`
                 (__)
                 (oo)
           /------\/
          / |    ||
         *  /\---/\\
            ~~   ~~
..."Have you mooed today?"...`))

Вихід:

                -       
            /--(-\--(__  
          /|~~---/~||/oo))
..."Have*you/mooed~today?"...

Ще один приклад:

console.log(fall(`
 (\__/)  .~    ~. ))
 /O O  ./      .'
{O__,   \    {
  / .  . )    \\
  |-| '-' \    }
 .(   _(   )_.'
'---.~_ _ _&`))

Вихід:

    _ , /            
  OO/__'_.. .         
 {.(|-|.(O'))/.~{      
/('---.~___-_&)_.'}\~.'))

Негольована функція

function fall(input) {
  let move = true
  let lines = input.split("\n").map(line => line.split(""))
  let isSpace = c => c == null || c == " "
  loop: for (;;) {
    for (let y = 0; y < lines.length - 1; y++) {
      let line = lines[y]
      for (let x = 0; x < line.length; x++) {
        let ch = line[x]
        if (!isSpace(ch)) {
          let dx = 0
          if (isSpace(lines[y+1][x])) { dx = 2 }
          else if (isSpace(lines[y+1][x-1])) { dx = 1 }
          else if (isSpace(lines[y+1][x+1])) { dx = 3 }
          if (dx) {
            lines[y + 1][x + dx - 2] = ch
            lines[y][x] = " "
            continue loop
          }
        }
      }
    }
    break
  }
  return lines.map(line => line.join("")).join("\n")
}

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