作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
public class Main2 {
public static void main(String[] args) {
List<Integer> list = Arrays.asList(2,4,3,-5,-7);
Collections.sort(list);
int i = 0;
int j = list.size()-1;
int min = 1000;
while (true) {
int sum = list.get(i)+list.get(j);
if (mod(sum) < min) {
min = mod(sum);
}
if (sum < 0) {
i++;
}
else if (sum ==0 ) {
i++;
j--;
}
else {
j--;
}
if (j <= i) {
break;
}
}
System.out.println(min);
}
private static int mod(int sum) {
return sum < 0 ? -sum : sum;
}
}
上面的代码是通过添加任意两个元素来找到最接近于零的和。但我无法弄清楚(不使用循环)流如何帮助编写更清晰、可读的代码。我所看到的是,如果在 for 循环内部没有太多逻辑,那么使用流会使代码更干净。
最佳答案
您可以流式传输该列表,并根据再次流式传输的同一列表flatMap
它,然后使用该流的min
方法。代码肯定会更短,但是否更容易阅读就在于仁者见仁智者见智了:
int min = list.stream()
.flatMapToInt(i -> list.stream()
.filter(j -> !i.equals(j))
.mapToInt(j -> i + j)
)
.map(Math::abs)
.min()
.getAsInt();
关于java - 函数式编程如何变得更好 (Java 8),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41361033/
我在 android 代码中使用 asmack XMPP。我可以正常登录 XMPP 服务器,但是当我尝试创建新用户时出现问题。我想要实现的是: 以管理员身份登录。 创建一个新用户。 从管理员注销。 以
这是我的标记页面,其中有一个按钮可以从数据库中搜索数据并显示在网格中 这是我背后的代码 if (!IsPostBack) { LblInfo.Text = "Page Load
当我多次将相同的 float 值插入到我的集合中时,本应花费恒定时间的 x in s 检查变得非常慢。为什么? 时序x in s的输出: 0.06 microseconds 0.09 mi
我有一个小型聊天客户端,可以将所有历史记录存储在 sqlite 数据库中。当用户单击我的应用程序中的 history 选项卡时,我的应用程序会获取所有相关历史记录并将其显示在 QWebView 中。我
我是一名优秀的程序员,十分优秀!