微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用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);
}

原文地址:https://www.jb51.cc/csharp/100369.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐