Код Гольф Гольф Гольф


24

Golf Challenge

Враховуючи нижче ASCII "Зелений".

|          |
|  |>      |
|  |       |
|  O       |
|          |
|          |
|          |
|          |
|          |
|          |

Нехай |позначає стіну
Нехай |позначає половину прапора полюса
Нехай >позначає прапор на полюсі
Нехай Oпозначає отвір
Нехай oпозначає кулю

Розміри "Зеленого" - 10х10. Між двома стінами є десять просторів |.
Є також десять пробілів, порожні чи ні між верхнім і нижнім зеленим.

Виклик

Введіть значення x і y або генеруйте два випадкових числа, щоб "вистрілити" м'яч для гольфу на зелений.
Якщо згенерований x, y не торкається отвору чи виводу прапора / виводу прапора "Спробуйте ще раз!"
Якщо генерований x, y потрапляє у вихідний отвір "Отвір в одному!"
якщо генерований x, y потрапляє на полюсний вихід "Lucky Shot!"
якщо згенерований x, y потрапляє на прапорці "Close one!"

Після пострілу виведіть розташування кулі на зеленому кольором на "" o, замінивши будь-який символ, який він потрапив. Також виведіть відповідну приказку вище.

Приклади:

//Hole in one example, the O was replaced with a o
Randomed x = 3
Randomed y = 4

"Hole in One!"

|          |
|  |>      |
|  |       |
|  o       |
|          |
|          |
|          |
|          |
|          |
|          |


//Clone example, the top half of the pole was replaced with a o
Randomed x = 3
Randomed y = 2

"Lucky Shot!"

|          |
|  o>      |
|  |       |
|  O       |
|          |
|          |
|          |
|          |
|          |
|          |

//Lucky Shot example, the > was replaced with a o
Randomed x = 4
Randomed y = 2

"Close One!"

|          |
|  |o      |
|  |       |
|  O       |
|          |
|          |
|          |
|          |
|          |
|          |

//Try Again example, the <space> was replaced with a o
Randomed x = 5
Randomed y = 1

"Try Again!"

|     o    |
|  |>      |
|  |       |
|  O       |
|          |
|          |
|          |
|          |
|          |
|          |

Будьте веселі і удачі, і оскільки це найкоротший код виграє!


Чи прапор / стовп завжди на одній позиції?
corvus_192

Ви можете залишити його там, де він є, або повеселитися з ним і перемістити його. Я подумав, що це буде занадто сильно боліти, щоб перемістити його, але я думаю, що це додає цікавого завдання. Якщо ви перемістите його, я би переконався, що 2 <h <= 10, де h - індекс висоти отвору. Таким чином прапор не з екрану.
jacksonecac

2
Або візьміть два параметри i і k, де 0 <i <= 10 і 0 <k <= 10, або встановіть i і k, використовуючи генерацію випадкових чисел
jacksonecac

1
@ corvus_192 абсолютно
jacksonecac

1
Ці вихідні рядки болісні для гольфу з кодом. Оскільки відповіді ще немає, подумайте про те, щоб дозволити сприймати їх як вхідні дані
Луїс Мендо,

Відповіді:


10

JavaScript (ES6) 210 208 193 184 байт

f=(a,b)=>((s=[...(`
|          |`).repeat(10)])[17]=s[30]='|',s[18]='>',s[43]=0,s[a+=1+b*13]='o',(a-17&&a-30?a-18?a-43?'Try Again!':'Hole in One!':'Close One!':'Lucky Shot!')+s.join``)
  • -9 байт більше ніж Хеді

Демо


8

Желе , 78 байт

ċЀ®Ḍị“ȷþḄ7Ẋ“þẹƊ⁴ḳL&Ṛ“qĠṂ®““ÞzḊṁġ“»;”!Ṅṛ
⁶ẋ“€¡®µC‘ż“|>|O”©F”o⁸¦Ç
ṭḌ‘Çs⁵j@€⁾||Y

Пограйте у майстерність гри або лайно-стрілянину на TryItOnline!

(Crap-shoot коштує більше байтів).

Як?

ṭḌ‘Çs⁵j@€⁾||Y - Main link: x, y (0-based)
ṭ             - tack            -> [y, x]
 Ḍ            - cast to decimal -> 10y+x
  ‘           - increment       -> 10y+x+1
   Ç          - call last link (1) as a monad
    s⁵        - split into chunks of size 10 (rows of green display)
         ⁾||  - literal ['|','|']
      j@€     - join €ach  with reversed @rguments (make the border)
            Y - join with line feeds
              - implicit print

⁶ẋ“€¡®µC‘ż“|>|O”©F”o⁸¦Ç - Link 1, Make green & place the ball: decimal 1-based location
  “€¡®µC‘               - code page indexes -> [12,0,8,9,67]
⁶                       - literal ' '
 ẋ                      - repeat (vectorises)
         ż              - zip with
          “|>|O”        - literal ['|','>','|','O']
                ©       -     and place the flag parts into the register
                 F      - flatten list
                     ¦  - apply to index at
                    ⁸   - input value
                  ”o    - literal 'o'
                      Ç - call the last link (2) as a monad

ċЀ®Ḍị“ȷþḄ7Ẋ“þẹƊ⁴ḳL&Ṛ“qĠṂ®““ÞzḊṁġ“»;”!Ṅṛ - Link 2, Print message: green with ball
   ®                                     - read register (the flag parts)     | > | O
ċЀ                                      - count occurrences e.g. HoleInOne: [2,1,2,0]
    Ḍ                                    - cast to decimal                  ->2120
     ị                                   - index into (1-based & modular) 2120 % 6 = 2
      “ȷþḄ7Ẋ“þẹƊ⁴ḳL&Ṛ“qĠṂ®““ÞzḊṁġ“»      - compressed list of (6) strings:
              ...["Lucky Shot","Hole in One","Try Again","","Close One",""]
                                   ;     - concatenate with
                                    ”!   - literal '!'
                                      Ṅ  - print with linefeed
                                       ṛ - yield right argument (the green)

8

Python 2, 290 264 262 252 248 245 байт

Це не дуже і не коротко, але я втомився, і це перша відповідь Python. Введіть знімок у форматі x, y.

Редагувати

Гольф від 26, переробивши спосіб складання списку. Досі не пощастить з довгим, якщо заява, хоча.

-2, замінивши довгий, якщо словником, і коротший, якщо.

-10, завдяки @ Noodle9 - я пропустив це :)

-4 - ще раз дякую :)

Ще 3 вимкнено. Спасибі.

x,y=input();a=[' ']*120;a[15]=a[27]='|';a[16],a[39],b='>','0',x+y*12
a[b],k='o',"Lucky Shot!";l={16:"Close One!",15:k,27:k,39:"Hole in One!"}
print l[b]if b in l else"Try Again!"
for z in range(10):c=z*12;a[c]=a[c+11]='|';print''.join(a[c:c+12])

Для всіх, хто цікавиться логікою, незахищений коментарями (1316 байт, але все ще легко вміщується на 3,5-дюймовий диск, якщо хтось їх пам’ятає):

x,y=input()                                     #Get the input as a tuple
a=[' ']*120                                     #Create a great big list of spaces for the whole green
a[15]=a[27]='|'                                 #Put the flag pole in place
a[16]='>'                                       #Add the flag
a[39]='0'                                       #Add the hole
b=x+y*12                                        #Get the absolute position in the list of the input tuple 
a[b]='o'                                        #Place the ball on the green
k="Lucky Shot!"                                 #Set a variable for k because it is long and we're going to use it twice
l={16:"Close One!",15:k,27:k,39:"Hole in One!"} #Create a dictionary of the comments (using k)
print l[b]if b in l else"Try Again!"            #If the absolute index is in the dict then print it otherwise print the default
for z in range(10):                             #Loop through the length of the green
    c=z*12                                      #Set a variable for the start point of each line
    a[c]=a[c+11]='|'                            #Add the left and right walls
    print''.join(a[c:c+12])                     #Print each line in turn. Because this is in a for loop then Python will deal with newlines

Однозначно вперше для мене, що словник був найкращим форматом даних у проблемі з гольфу.


ви можете використовувати все, що є доступним, як ключ словника
Noodle9

6

C, 236 байт

n,m;char*a[]={"Try Again!","Hole in One!","Lucky Shot!","Close One!"};f(x,y){n=130;m=142-y*13-x;puts(a[(m==87)+2*(m==113|m==100)+3*(m==112)]);while(n--)putchar(m==n?111:n%13?n%13==1|n%13==12|n==113|n==100?124:n==112?62:n==87?79:32:10);}

Безголівки:

n,m;
char*a[]={"Try Again!","Hole in One!","Lucky Shot!","Close One!"};
f(x,y){
 n=130;
 m=142-y*13-x;
 puts(a[(m==87) + 2*(m==113|m==100) + 3*(m==112)]); 
 while(n--)
  putchar(m==n?111:n%13?n%13==1|n%13==12|n==113|n==100?124:n==112?62:n==87?79:32:10);
}

3

Скала, 238 байт

(x:Int,y:Int)=>{val r="<          |\n"
('"'+(if(x==2&y==3)"Hole in One!"else
if(x==2&(y==1|y==2))"Lucky Shot!"else
if(x==3&y==1)"Close One!"else
"Try again!")+"'",(r+"|  |>      |\n|  |       |\n|  O       |\n"+r*6)updated(1+x+13*y,'o'))}

Використання нульової індексації.

Це занадто читабельно :(

Пояснення:

(x:Int,y:Int)=>{                                      //define an anonymous function
  val r="|          |\n"                                //a shortcut for an empty row
  (                                                     //return a tuple of
    '"'+                                                  //a double quote
    (if(x==2&y==3)"Hole in One!"                          //plus the correct string
    else if(x==2&(y==1|y==2))"Lucky Shot!"
    else if(x==3&y==1)"Close One!"
    else "Try again!"
    )+"'"                                                 //and another quote
  ,                                                     //and
    (r+"|  |>      |\n|  |       |\n|  O       |\n"+r*6) //the field
    updated(1+x+13*y,'o')                                //with the (1+x+13*y)th char replaced with a ball
  )
}

Я використовував формулу 1+x+13*yдля обчислення правильного індексу, оскільки кожен рядок має 13 символів (2 межі, новий рядок та 10 пробілів) плюс зміщення одного, оскільки (0,0) має бути другим знаком.


3

Perl, 225 209 байт

$_="|".$"x10 ."|
";$_.=sprintf("|  %-8s|
"x3,"|>","|",O).$_ x6;$d="Try Again!";($x,$y)=@ARGV;say$x==3?$y~~[2,3]?"Lucky Shot!":$y==4?"Hole in One!":$d:$x==4&&$y==2?"Close One!":$d;substr($_,$y*13-13+$x,1)=o;say

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


3

Вугілля деревне , 99 байт

NαNβ× ⁵↑¹⁰‖C←J⁴¦²←>↓²OM⁴↖P⁺⎇∧⁼α³⁼β⁴Hole in One⎇∧⁼α³⁼¹÷β²Lucky Shot⎇∧⁼α⁴⁼β²Close One¦Try Again¦!Jαβo

Бере вхід на основі 1, з пробілом, на stdin. Більшість коду призначена для друку (одного з) чотирьох повідомлень. Спробуйте в Інтернеті!

Примітка: Деревне вугілля все ще триває. Цей код працює з поточної комісії . Якщо вона перестане працювати в майбутньому (зокрема, якщо посилання TIO не працює, як очікувалося), надішліть мені пінг, і я спробую додати неконкуруючу оновлену версію, яка працює.

Пояснення

NαNβ       Read two inputs as numbers into variables α and β

               Construct the green and flag:
× ⁵          Print to canvas 5 spaces
↑¹⁰          Print 10 | characters going up
‖C←         Reflect and copy leftward
             At this point, borders of green are complete; cursor is above left wall
J⁴¦²        Jump 4 units right and 2 down
←>           Print the flag, going leftward
↓²           Print the pin (2 | characters), going downward
O            Print the hole
             The last print was rightward by default, which means we're now at (4,4)
M⁴↖         Move 4 units up and left; cursor is above left wall again

               Add the proper message:
⎇∧⁼α³⁼β⁴    If α is 3 and β is 4 (in the hole):
Hole in One  
⎇∧⁼α³⁼¹÷β²  Else if α is 3 and β is 2 or 3 (hit the pin):
Lucky Shot
⎇∧⁼α⁴⁼β²    Else if α is 4 and β is 2 (hit the flag):
Close One
             Else:
¦Try Again
⁺...¦!       Concatenate a ! to the string
P           Print it without changing the cursor position

               Overwrite the appropriate spot with o:
Jαβ         Jump α units right and β units down
o            Print o

3

Мозг-Флак , 1466, 1938 байт

(<()>)<>((()()()()()){}){({}[()]<(((((((()()()()()){})){}{}()){}){})<((()()()()()){}){({}[()]<(((((()()){}){}){}){})>)}{}>)((()()()()()){})>)}{}((((()()){}){}){}()){({}[()]<({}<>)<>>)}{}{}{}(((((()()()()()){})){}{}()){})(((((((()()()()()){})){}{}()){}){})<(((()()()){}){}()){({}[()]<({}<>)<>>)}{}{}>)(((()()()){}){}()){({}[()]<({}<>)<>>)}{}{}(((((()()()){}){}){}){}){<>({}<>)}(<>{}((((({}[()])){}){})){}{}{}()<>{}){({}[()]<({}<>)<>>)}{}({}<(((((((()()()){}){})){}{}())){}{}){<>({}<>)}>)(({}<((({}(((()()){}){}){}()){})[()])>)[((((()()){}){}){}){}]){({}[(((()()){}){}){}]){({}[((()()()){}()){}]){{}{}(((((((((()()()){}()){}){}()){}){})[()()()()()])[(()()()){}()])<(((((()()()()()){}){}){}()){}())(((((()()){}){}){}){})>(((()()){}){}){}())(([((()()()){}()){}](({})<>)<>)[((()()){}){}])((<>{}<>[()()()()])[(((()()()()()){}){}){}()])<>}{}{{}((((((((((()()()){}){}){}()){}){}())<>)<>((()()())){}{})[(((()()()()()){})){}{}()])<(((((()()){}){}){}){})((((<>{}<>)((()()()){}()){})[()()()()])[()()()])>[((()()()){}){}])<>}}{}{{}((((((((()()()){}){}){}()){}){}())((()()())){}{})[(((()()()()()){})){}{}()])((((((()()){}){}){}){})<(((((()()()()()){}){({}[()])}{}){})[()()()()()])>)((((((((()()()){}){}){}()){}){}())(()()()){}())()()())((((((()()()){}){}){})){}{})<>}{}}{}{{}(((((((()()()()()){}){({}[()])}{}){})[()()()()()])[((()()){}){}])(()()()){})(((((((((((()()){}){}){}){})))({}<({}{}())>)[()()()()]){}())[(()()()){}()])[(((()()()()()){})){}{}])<>}<>(((((()()){}){}){}()){})

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


Я виграв?


Вам здається, що нульовий байт друкується в кінці першого рядка виводу.
0

@ 1000000000 так. Я вирішив це з моїм останнім оновленням. Дякую, що вказали на це.
MegaTom

2

TI-Basic, 183 байти

Input X
Input Y
X+1➡X
ClrHome
For(I,1,10
Output(I,1,"|
Output(I,12,"|
End
Output(2,4,"|>
Output(3,4,"|
Output(4,4,"O
Output(Y,X,"o
13
Output(1,Ans,"TRY AGAIN!
If X=4 and Y=4
Output(1,Ans,"HOLE IN ONE!
If X=5 and Y=2
Output(1,Ans,"CLOSE ONE!
If Y=2 or Y=3 and X=4
Output(1,Ans,"LUCKY SHOT!

Подякуйте за добро TI-Basic використовує лексеми.

|Зазвичай не можуть бути надруковані, але в наборі символів.

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

Пізніше я додам скріншот прикладу програми.


2

Groovy - 235 байт

Моя перша спроба - рихле закриття, що приймає 2 цілих числа від 0 до 9 як координати X і Y для пострілу.

{j, k-> j ++; c = ''; b = '|'; f = '>'; h = 'O'; s = ''; v = [2: b, 3: b, 4: h ]; (0..9) .each {y-> l = (b + s * 10 + '| \ n'). Chars; l [3] = v [y] ?: s; l [4] = y == 2? f: s; if (k == y) {m = [(s): "Спробуйте ще раз!", (b): "Пощастило пострілу!", (f): "Закрийте одного!", (h): 'Отвір в одному!'] ["" ​​+ l [j]]; l [j] = 'o'}; c + = l}; c + = m}

2

Діалог APL , 147 (або 127) байт

Приймає (y, x) як аргумент.

{G10 10''
G[⍳4;3]←' ||O'
G[2;4]←'>'
G[⊃⍵;⊃⌽⍵]←'o'                G[y;x]←
⎕←'|',G,'|'                  Print G with sides
4 3≡⍵:'Hole in One!'         If (y,x)  (4,3)
(⊂⍵)∊2 3∘.,3:'Lucky Shot!'   If (y,x)  {(2,3), (2,3)}
2 4≡⍵:'Close One!'
'Try Again!'}                Else

З версії 16.0 ми можемо майже вдвічі зменшити кількість байтів у нового @оператора;

@ ставить лівий операнд у позиції правого операнда в правому аргументі: NewChars @ Positions ⊢ Data

{⎕←'|','|',⍨' ||O>o'@((2 4)⍵,⍨3,⍨¨⍳4)⊢10 10''
4 3≡⍵:'Hole in One!'
(⊂⍵)∊2 3∘.,3:'Lucky Shot!'
2 4≡⍵:'Close One!'
'Try Again!'}

Трохи модифікований код, щоб зробити його допустимим у TryAPL:

Отвір в одному , Lucky Shot 1 , Lucky Shot 2 , Close one , Random


1

Черепаха , 164 байти

В черговий раз, демонструючи баланс Туртледа між гольфністю та багатослівністю для найпростіших речей (наприклад, збільшення числа), Туртлед б'є всіх, крім гольфів.

6;11[*'|:'|>;<u]'|rrr'O8:'|u'|>;'|ddd'|l'|uuu<"|>":l'|u'|>11;'|?<:?;( #Try Again!#)(>#Close One!#)(|#Lucky Shot!#)(O#Hole in One!#)'o[|r][ u]dl[|l][ u]u@"-,r["+.r_]

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

Зауважте, що це півіндексовано та наполовину індексовано; x - індексований, y - індексований нулем; 3,3 - отвір в одному


1

R, 230 226 байт

M=matrix("|",10,10);M[2:9,]=" ";M[34]="0";M[4,2:3]="f";M[15]=">";function(x,y){m=switch(M[y,x],">"="Close One","f"="Lucky Shot","0"="Hole In One","Try again");M[y,x]="o";cat(m,"!\n",sep="");cat(gsub("f","|",M),sep="",fill=10)}

Завдяки @billywob на -2 байти, помітити M[a,b]рівносильноM[c] в декількох випадках.

Прикро, що два catвиклики (!) Не можуть бути catоб'єднані в один, оскільки fillаргумент псує повідомлення. Арг!


1
Перемістіть створення матриці всередині функції та зробіть її в безіменному:function(x,y){M=matrix("|",10,10);M[2:9,]=" ";M[34]="0";M[4,2:3]="f";M[15]=">";m=switch(M[y,x],">"="Close One","f"="Lucky Shot","0"="Hole In One","Try again");M[y,x]="o";cat(m,"!\n",sep="");cat(gsub("f","|",M),sep="",fill=10)}
Billywob

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