類似商品の平均価格から新商品の価格を求めたい。関数get-k-similarはk最近傍法を使用しますが、この出力を返します
((list rating age price) proximity)
。
For example, 2-similar would be:
(((5.557799748150248 3 117.94262493533647) . 3.6956648993026904)
((3.0921378389849963 7 75.61492560596851) . 5.117886776721699))
同様のアイテムの平均価格を見つける必要があります。つまり、平均117と75です。反復するためのより良い方法はありますか?私の関数はあまりにも醜いようです。
(define (get-prices new-item)
(define (average-prices a-list)
(/ (cdr
(foldl (λ(x y) (cons (list 0 0 0)
(+ (third (car x)) (third (car y)))))
(cons (list 0 0 0) 0)
a-list))
(length a-list)))
(let ((similar-items (get-k-similar new-item)))
(average-prices similar-items)))