A tarefa
Escreva uma função L () que recebe dois argumentos de tupla de coordenadas na forma (x, y) e retorna sua respectiva função linear na forma (a, c), onde a é o coeficiente do termo x ec é o intercepto em y.
Você pode assumir que a entrada não será uma linha perpendicular ao eixo xe que as duas entradas são pontos separados.
Pontuação
Este é o Code Golf: o programa mais curto vence.
Nota: Não há uso de funções matemáticas além dos operadores básicos (+, -, /, *).
Exemplo
Aqui está minha solução não-golfe em Python.
def L(Point1, Point2):
x = 0
y = 1
Gradient = (float(Point1[y]) - float(Point2[y])) / (float(Point1[x]) - float(Point2[x]))
YIntercept = Point1[y] - Gradient * Point1[x]
return (Gradient, YIntercept)
Resultado:
>>> L( (0,0) , (1,1) )
(1.0, 0.0)
>>> L( (0,0) , (2,1) )
(0.5, 0.0)
>>> L( (0,0) , (7,1) )
(0.14285714285714285, 0.0)
>>> L( (10,22.5) , (5,12.5) )
(2.0, 2.5)
L((0,0),(0,0))
?
L( (0,0) , (0,1) )
?