Dans ce code de golf, vous devrez déterminer la direction du tir le plus court qui touche exactement n coussins avant de tomber dans une poche.
La table de billard est une table de billard 6 poches avec les caractéristiques suivantes:
- Les dimensions sont variables ( a x b )
- Pas de frottement: la balle roulera pour toujours jusqu'à ce qu'elle tombe dans une poche
- Les poches et les balles sont presque nulles. Cela signifie que le ballon ne tombera dans la poche que s'ils ont la même position.
- La balle est placée dans le trou en bas à gauche au début (mais n'y tombe pas)
Créez un programme ou une fonction complète qui prend les dimensions ( a , b ) de la table et le nombre de coussins à frapper n en entrée et renvoie l'angle en degrés du chemin le plus court atteignant exactement n coussins avant de tomber dans une poche.
- a > 0
- b > 0
- 0 <= n <10000000
- 0 < alpha <90 (en degrés) précision: au moins 10 ^ -6
exemples :
avec a = 2, b = 1, n = 1, il y a trois chemins possibles: (1) (2) (3) sur la figure suivante. le nombre (1) est le plus court donc la sortie doit être atan (2) = 63,43494882292201 degrés
La solution pour a = 2, b = 1, n = 4 est atan (4/3) = 53.13010235415598 degrés
échantillons d'essai:
a = 2, b = 1, n = 1, -> alpha = 63.43494882292201
a = 2, b = 1, n = 2, -> alpha = 71.56505117707799
a = 2, b = 1, n = 3, -> alpha = 75.96375653207353
a = 2, b = 1, n = 4, -> alpha = 53.13010235415598
a = 2, b = 1, n = 5, -> alpha = 59.03624346792648
a = 2, b = 1, n = 6, -> alpha = 81.86989764584403
a = 4.76, b = 3.64, n = 27, -> alpha = 48.503531644784466
a = 2, b = 1, n = 6, -> alpha = 81.86989764584403
a = 8, b = 3, n = 33, -> alpha = 73.24425107080101
a = 43, b = 21, n = 10005, -> alpha = 63.97789961246943
C'est le golf code / billard: le code le plus court gagne!
n
coussins, ou du moins lesn
coussins?