Це одна дивна гора!


10

Натхненний Показати ланцюжок маленьких гір з непарним номером на вершині! автор @sygmei .

Навіщо мати ланцюг гір, коли ти можеш мати один масивний?

Створіть програму, яка приймає вхідне число та друкує гору з кожним непарним числом до вхідного номера.

(Де "південний захід" означає directly below and to the left, а "південний схід" означає directly below and to the right)

Кожне число матиме /південний захід від нього та \південний схід. Він починається 1вгорі, і наступне число піде на південний захід від /або на південний схід від \. Наступний номер буде проходити в рядку, найближчому до вершини та зліва, найбільш можливого.

Для багатозначного числа просто перша цифра повинна знаходитися в потрібному місці, а інші цифри безпосередньо після, і лише перша цифра повинна мати \і /виходити з неї.

Гора до 1 або 2 - це просто:

 1
/ \

Гора до 3 або 4 - це просто:

   1
  / \
 3
/ \

Для 25 або 26:

         1
        / \
       3   5
      / \ / \
     7   9   11
    / \ / \ / \
   13  15  17  19
  / \ / \ / \ / \
 21  23  25
/ \ / \ / \

Останні два рядки, де вхід 121:

 111 113 115 117 119 121
/ \ / \ / \ / \ / \ / \

І останні два рядки, де вхід 1019:

 993 995 997 999 1001100310051007100910111013101510171019
/ \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \

Ви можете припустити, що вхід буде більшим за 0 і менше 10001 (виключно).

Пробіли пройдуть у порядку, а додаткові провідні місця проміжки добре, якщо на всіх лініях є однакові.

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

Відповідь на це, що не має права, можна знайти в Інтернеті тут (у Python на repl.it), якщо вам потрібно більше тестових випадків.


Якщо вхід менше 101, то чому у вас 121 тестова шафа?
LegionMammal978

@ LegionMammal978 Я мав на увазі 10001, виправлений зараз. Дякую!
Художник

1
Складніше, ніж оригінальний, я спробую: D
Sygmei

Відповіді:


5

05AB1E , 54 52 47 46 байт

ÅɹL£D€g__ÏRv"/ \ "yg×N·©úˆyvy4yg-ð×}J®>úˆ}¯R»

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

Пояснення

                                                # implicit input n
ÅÉ                                              # push a list of uneven numbers up to input
  ¹L£                                           # divide into sublists of length 1,2,3...n
     D€g__Ï                                     # remove empty sublists
           R                                    # reverse list
            v                                   # for each sublist
             "/ \ "                             # push the string "/ \ "
                   yg×                          # repeat it len(sublist) times
                      N·©ú                      # prepend (sublist index)*2 spaces
                          ˆ                     # add to global list
                           yv                   # for each number in sublist
                             y4yg-ð×            # prepend spaces until length is 4
                                    }           # end inner loop
                                     J          # join to string
                                      ®>ú       # prepend (sublist index)*2+1 spaces
                                         ˆ      # add to global list
                                          }     # end outer loop
                                           ¯    # push global list
                                            R   # reverse it
                                             »  # join rows by space and columns by newline
                                                # implicitly print

Я міг би врятувати 5 байт, ÅɹL£D€g__ÏRv"/ \ "yg×N·©úˆy4jJðÛ®>úˆ}¯R»якби я лише натиснув цю помилку для j, про яку я писав кілька тижнів тому :


3

Пакетна, 335 байт

@echo off
set i=
set/ac=w=0
:l
set i=  %i%
set/aw+=2,c+=w
if %c% lss %1 goto l
set s=
set t=
set/ac=w=1
for /l %%a in (1,2,%1) do call:c %%a
echo  %s%
echo%t%
exit/b
:c
if not %c%==0 goto g
echo%i%%s%
set i=%i:~2%
echo%i%%t%
set s=
set t=
set/aw+=1,c=w
:g
set n=%1   (three trailing spaces)
set s=%s%%n:~0,4%
set t=%t% / \
set/ac-=1

@Artyer Я впевнений, що cmd /Q /C file.batнараховує 3 зайвих байти, але це все-таки краще, ніж @echo off. Ви повинні опублікувати це на запитання щодо пакетних підказок.
Ніл

3

Python 2, 160 149 143 байт

Дякуємо TFeld за збереження 11 байт та Artyer за збереження 6 байт

x=range(1,input()+1,2);y=[];i=1
while x:y+=[''.join('%-4d'%j for j in x[:i]),'/ \ '*len(x[:i])];x=x[i:];i+=1
while y:print' '*~-len(y)+y.pop(0)

Можна зробити i=len(y)і for l in y:print' '*i+l;i-=1замість for i,l in enumerate(y):print(len(y)-i-1)*' '+l-10 байт
TFeld

Також я думаю, що ви можете перейти \\ до місця \ після пробілу
TFeld

Ви можете змінити останні два рядки на while y:print' '*-~len(y)+y.pop(0). Це економить 3 байти.
Artyer

1
@Rod На жаль ... Я мав %-4dна увазі залишити це виправданням до 4.
Artyer

1
@Artyer woah, це негативне значення зліва виправдовується для мене новим: D, приємний трюк
стрижень

2

Perl, 134

133 байти + 1 за -pопцією

 $l="/ \\ ";$t=" ";while($c++<$_) {$t.=sprintf'%-4d',$c++;$v.=$l;if ($i++>=$j){$t=~s/^/  /gm;$t.="
  $v
 ";$i=$v="";$j++}}$_="$t
$v";

Відформатована версія (оригінальна версія для гольфу використовує справжні "нові рядки" замість \ n)

$l="/ \\ ";
$t=" ";
while($c++<$_) {
   $t.=sprintf'%-4d',$c++;
   $v.=$l;
   if ($i++>=$j){
      $t=~s/^/  /gm;
      $t.="\n  $v\n ";
      $i=$v="";
      $j++
   }
}
$_="$t\n$v";

2

Bash, 425 байт

f() { k=0; o=""; l=1; for (( c=1; c<=$1; c++ )); do o="$o$c "; let c++ k++; if [ $l -eq $k ]; then o=$o"\n"; k=0; let l++; fi; done; s=$[$(echo -e $o | wc -l)*2-1]; p() { for c in $(seq $1); do echo -n " "; done }; IFS=$'\n'; for n in $(echo -e $o); do unset IFS; p $s; let s--; for w in $n; do echo -n "$w"; p $[4-${#w}]; done; echo; p $s; for c in $(seq $(echo $n|wc -w)); do echo -n "/ \ "; done; echo; let s-- j++; done }

Відформатовано:

l=1
k=0
o=""
for (( c=1; c<=$1; c++ ))
do
        o="$o$c "
        let c++ k++
        if [ $l -eq $k ]
        then
                o=$o"\n"
                k=0
                let l++
        fi
done
s=$[$(echo -e $o | wc -l)*2-1]
p() {
        for c in $(seq $1)
        do
                echo -n " "
        done
}
IFS=$'\n'
for n in $(echo -e $o)
do
        unset IFS
        p $s
        let s--
        for w in $n
        do
                echo -n "$w"
                p $[4-${#w}]
        done
        echo
        p $s
        for c in $(seq $(echo $n|wc -w))
                do echo -n "/ \ "
        done
        echo
        let s-- j++
done
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.