![](/img/trans.png)
[英]Is there a faster way to check if an item in a list if it is greater than, less than, equal to a certain number?
[英]How to check if number in a list is greater than and in continuation to next number in list
我在下面有一个包含 startRange 和 endRange 的对象示例列表。 我想检查我的第一个元素 endRange 是否延续到下一个元素中的 startRange 并生成一个 output 如果数字连续,则可以缩短范围。 参见样品 output。
样本输入 -
开始范围:1005000,结束范围:1005799
开始范围:1005800,结束范围:1005899
开始范围:1005900,结束范围:1005999
开始范围:2096000,结束范围:2096999
开始范围:2097000,结束范围:2097999
开始范围:2205010,结束范围:2205019
样品 Output -
开始范围:1005000,结束范围:1005999
开始范围:2096000,结束范围:2097999
开始范围:2205010,结束范围:2205019
这是我尝试过的 -
List<BinRange> finalRange = new ArrayList<>();
for (BinRange bin : list.getBinRanges()) {
rangeStart = bin.getRangeStart();
rangeEnd = bin.getRangeEnd();
System.out.println("startRange : " + rangeStart + ", endRange : " + rangeEnd);
long diff = Math.abs(rangeEnd - rangeStart);
if (diff == 1) {
continue;
} else {
rangeEnd = bin.getRangeEnd();
BinRange binRange = new BinRange(rangeStart, rangeEnd);
finalRange.add(binRange);
break;
}
}
您可以像这样连续成对地迭代它们:
static List<BinRange> check(final List<BinRange> ranges)
{
// trivial
if (ranges.size() < 2)
{
return ranges;
}
var resultRanges = new ArrayList<BinRange>();
Long prevStart = null;
for (int i = 1, rangesSize = ranges.size(); i < rangesSize; i++)
{
final BinRange prevRange = ranges.get(i - 1);
final BinRange currRange = ranges.get(i);
if (prevStart == null)
{
prevStart = prevRange.getRangeStart();
}
if (prevRange.getRangeEnd() != currRange.getRangeStart() - 1)
{
resultRanges.add(prevStart == prevRange.getRangeStart()
? prevRange // recycle instance
: new BinRange(prevStart, prevRange.getRangeEnd()));
prevStart = null;
}
if (i == rangesSize - 1)
{
resultRanges.add(prevStart == null
? currRange // recycle instance
: new BinRange(prevStart, currRange.getRangeEnd()));
}
}
return resultRanges;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.