微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 Java 流查找集合中最接近的对

如何解决使用 Java 流查找集合中最接近的对

我有一组元素,它们之间有距离度量。我正在寻找一种方法来从这个集合中找到最接近的一对元素。使用循环我将使用以下算法:

np.nan

有没有一种优雅的方式使用 Java 流来实现这个算法?

解决方法

可能是这样的:

Optional<SimpleEntry> closestPair = elements.stream()
    .flatMap(elem -> elements.stream()
        .filter(other -> !elem.equals(other))
        .map(other -> new SimpleEntry(elem,other))
    .min(Comparator.comparingDouble(e -> e.getKey().distance(e.getValue()));

但您可能希望将这些内联 lambda 提取为单独的方法。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。