是否有任何现有的 linq 函数或类似函数来检测有序列表中的值从小于零变为大于零的频率?
例如,值:
5
2
-2
-5
8 <--- First
6
2
0
1
-3
-5
-3
2 <--- Second
总数:2
当然 - 如果您使用 .NET 4 或更高版本,这当然很容易,使用Zip
:
// TODO: Consider how you want to handle 0 itself
var count = list.Zip(list.Skip(1), (x, y) => new { x, y })
.Count(pair => pair.x > 0 && pair.y < 0);
如果你对 VB 很了解,那应该不难转换成 VB :)
或者,如果你真的有一个列表,你可以在没有 LINQ 的情况下很容易地“手动”完成它:
int count = 0;
for (int i = 0; i < list.Count - 1; i++)
{
if (list[i] > 0 && list[i + 1] < 0)
{
count++;
}
}
您可以使用以下方法一次性实现Aggregate
:
seq.Aggregate(new { Count=0, LastN = 0}, (state, n) => new {
Count = state.Count + (n > 0 && state.LastN < 0 ? 1 : 0),
LastN = n == 0 ? state.LastN : n
}).Count
这考虑到您希望包含“渐进”转换,例如 -1,0,1。
但是,foreach 可能更容易,因为它更传统。它也会更快:
var count = 0;
var lastN = 0;
foreach(var n in seq) {
if(n > 0 && lastN < 0)
count++;
if (n != 0)
lastN = n;
}