Görev
(X, y) biçiminde iki Tuple koordinat argümanı alan ve (a, c) biçiminde ilgili doğrusal işlevlerini döndüren bir işlev L () yazın; burada a, x teriminin ve c'nin eş-etkinliğidir y kesme noktasıdır.
Girişin x eksenine dik bir çizgi olmayacağını ve iki girişin ayrı noktalar olduğunu varsayabilirsiniz.
puanlama
Bu Code Golf: en kısa program kazanır.
Lütfen Dikkat: Temel işleçlerin (+, -, /, *) dışında matematiksel işlevler kullanılmaz.
Misal
İşte Python'daki golf dışı çözümüm.
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)
Çıktı:
>>> 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) )?