5
Я новичок в F # и написал простой алгоритм, чтобы привыкнуть к языку, которому необходимо argMax
. Имеется ли в стандартной библиотеке функция для поиска элемента списка, который максимизирует функцию? То есть, если есть существующая функция, которая ведет себя как этот:Имеет ли библиотека F # стандартную функцию для `argMax`?
let argMax f xs =
let rec go a fa zs =
match zs with
| [] -> a
| z :: zs' ->
let fz = f z
if fz > fa
then go z fz zs'
else go a fa zs'
match xs with
| [] -> invalidArg "xs" "empty"
| x :: xs' -> go x (f x) xs'