使用C#将整数集转换为范围

前端之家收集整理的这篇文章主要介绍了使用C#将整数集转换为范围前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
将一组整数转换为一组范围的最惯用的方法是什么?

例如.给定{0,1,2,3,4,7,8,9,11}我希望使用C#获得{{0,4},{7,9},{11,11}}

这个问题已在C @ Solution in C++中得到解答

解决方法

这不是很有效,但它是惯用的:
var nums = new HashSet<int>{0,11};
IEnumerable<Tuple<int,int>> ranges = Enumerable.Zip(
    nums.Where(n => !nums.Contains(n - 1)),nums.Where(n => !nums.Contains(n + 1)),Tuple.Create);

更高效,假设它已分类

public IEnumerable<Tuple<int,int>> GetContiguousRanges(IEnumerable<int> nums)
{
    int start = nums.First();
    int last = start - 1;
    foreach (int i in nums)
    {
        if (i != last + 1)
        {
            yield return Tuple.Create(start,last);
            start = i;
        }
        last = i;
    }
    yield return Tuple.Create(start,last);
}

猜你在找的C#相关文章