Намалюйте вкладені радикали


13

Багато формул математики включають вкладені радикали (квадратні кореневі знаки всередині інших знаків квадратних коренів). Ваше завдання тут - намалювати їх за допомогою мистецтва ascii.

Технічні характеристики

Вам дадуть два цілих числа, кількість всередині радикала і кількість радикалів. Я думаю, що найкращий спосіб пояснити, що ви маєте зробити, - це на прикладі. Ось вихід для 2, 4:

        ____________________
\      /       _______________
 \    /  \    /     __________
  \  /    \  /  \  /   _____
   \/      \/    \/  \/ 2

Ось кілька речей, які слід зазначити:

  • Висота кожного радикала збільшується на одиницю
  • Довжина _'s завжди 5є висотою
  • Після останнього /і перед початком наступного внутрішнього радикала є пробіл
  • Число всередині ніколи не буде перевищувати 4 цифри
  • Якщо кількість радикалів дорівнює 0, просто виведіть число
  • Розмістити додаткові пробіли, щоб покласти його в прямокутник, ви вирішите
  • Це , тому найкоротший код у байтах виграє!

Випробування

2, 4:
        ____________________
\      /       _______________
 \    /  \    /     __________
  \  /    \  /  \  /   _____
   \/      \/    \/  \/ 2

23, 0:
23

4, 1:
  _____
\/ 4

1234, 3:
      _______________
\    /     __________
 \  /  \  /   _____
  \/    \/  \/ 1234

12
Я відчуваю, що це було б трохи кращим завданням, якби всі горизонтальні смуги мали закінчитися в одній точці.
Грег Мартін

Відповіді:


2

Python 3,5, 145 137 байт

def s(n,x):[([print(' '*j+'\\'+'  '*i+'/ '+' '*j,end='')for j in range(x-i-1,-1,-1)],print('  '*i+i*'_____'or n))for i in range(x,-1,-1)]

Трохи незворушений:

def s(n,x):
    for i in range(x,-1,-1):
        for j in range(x-i-1,-1,-1):
            print(' '*j+'\\'+'  '*i+'/ '+' '*j,end='')
        print('  '*i+i*'_____' or n)

Вихід:

s(2,4)
        ____________________
\      /       _______________
 \    /  \    /     __________
  \  /    \  /  \  /   _____
   \/      \/    \/  \/ 2

print(' '*i+'_____'*i or n)економить 7 байт. EDIT print(' '*i+i*'_____'or n)економить 8.
Джонатан Аллан

Дякую. Я не знав, що ти можеш використовувати "чи" так.
Джеймс Холліс

2

JavaScript, 133 132 131 байт

f=(n,r,q=r)=>~r?'1\\0/1 '[x='repeat'](d=q-r).replace(/\d/g,i=>' '[x](+i?d-=.5:r*2))+(r?' '[x](r*2)+'_'[x](5*r):n)+`
`+f(n,r-1,q):''


F=(n,r)=>console.log( f(n,r) )
F(2,4)
F(23,0)
F(4,1)
F(1234,3)
.as-console-wrapper{max-height:100%!important;top:0}


2

JavaScript (ES6), 124 байти

f=(s,n,i=0,r=(n,c=` `)=>c.repeat(n))=>n?r(n+n)+r(n*5,`_`)+`
`+f(s,n-1).replace(/^/gm,_=>r(i)+`\\${r(n+~i<<1)}/`+r(++i)):s+``
<div oninput=o.textContent=f(s.value,+n.value)><input id=s><input id=n type=number min=0><pre id=o>

Збережіть 3 байти, якщо першим параметром може бути рядок, а не число.


1

PHP, 178 байт

for($r=[" $argv[1]"];$i++<$argv[2];$r[]=$p("",2*$i).$p(_,5*$i,_))for($k=-1;++$k<$i;)$r[$k]=($p=str_pad)("\\".$p("",2*$k)."/",2*$i," ",2).$r[$k];echo join("\n",array_reverse($r));

так страшно довго.

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