0

是否有任何现有的 linq 函数或类似函数来检测有序列表中的值从小于零变为大于零的频率?

例如,值:

5
2
-2
-5
8  <--- First
6
2
0
1
-3
-5
-3
2  <--- Second

总数:2

4

2 回答 2

3

当然 - 如果您使用 .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++;
    }
}
于 2013-02-21T15:04:45.940 回答
1

您可以使用以下方法一次性实现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;
}
于 2013-02-21T15:52:49.373 回答