[英]Question about simplifying code related to loop iteration
我有一个关于编码的问题。 我得到一个任务,它是迭代一个元素列表来执行重复数据删除。
元素列表按时间排序并划分为子时间窗口。 在每个子时间窗口中,我需要根据某些业务逻辑选取已删除重复的元素。 根据业务逻辑,子时间窗口中的去重元素只有在子时间窗口中的所有元素都被迭代时才知道。 我的问题是如何简化此任务的编码。
我能想到的最好的是一些伪代码,如下所示
List<Element> deduplicated = new List();
Element subWindowPeekSignal = null;
Time subWindowEndTime = null;
elements.foreach(e -> {
if (subWindowPeekElement != null
&& subWindowEndTime != null
&& isElementInTimeWindow(e, subWindowEndTime) {
if (isIteratedElementHigherPriority(subWindowPeekElement, e)) {
subWindowPeekElement = e;
}
} else {
if (subWindowPeekElement != null) {
deduplicated.add(subWindowPeekElement);
}
subWindowPeekElement = e;
subWindowEndTime = getTime(e);
}
});
//the ugly statement outside of loop
deduplicated.add(subWindowPeekElement);
具体来说,如何避免循环外的最后一条语句? 是否有可能完成在循环或使用 java 流中收集所有重复数据删除元素的任务?
非常感谢,君
根据我团队的讨论,这是最好的解决方案。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.