我有一个有序列表,如0,1,2,6,7,10
我想得到数字增加1的集合.我想要第一个数字和计数或系列.
所以我得到
start = 0,count = 3
start = 6,count = 2
start = 10,count = 1
我怎么能在C#中做到这一点?
答案是我觉得最好的方式.对我来说,可读性比性能更重要.
定义一个简单的类来保存结果:
private class Set
{
public int Start = 0;
public int Count = 0;
}
Run Code Online (Sandbox Code Playgroud)
你可以使用这样的方法:
private static IEnumerable<Set> GetSets(List<int> src)
{
List<Set> rtn = new List<Set>();
int previous = int.MaxValue;
foreach (int i in src)
{
if (i == previous + 1)
{
rtn[rtn.Count - 1].Count += 1;
}
else
{
rtn.Add(new Set() { Start = i, Count = 1 });
}
previous = i;
}
return rtn;
}
Run Code Online (Sandbox Code Playgroud)
我并不热衷于它的神奇价值int.MaxValue
,但它在第一次迭代时节省了额外的逻辑.
GetSets(new List<int>() { 0, 1, 2, 6, 7, 10 })
正确调用可提供您所需的结果.
归档时间: |
|
查看次数: |
591 次 |
最近记录: |