加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 08:01:44 所属栏目:百科 来源:网络整理
导读:将一组整数转换为一组范围的最惯用的方法是什么? 例如.给定{0,1,2,3,4,7,8,9,11}我希望使用C#获得{{0,4},{7,9},{11,11}} 这个问题已在C @ Solution in C++中得到解答 解决方法 这不是很有效,但它是惯用的: var nums = new HashSetint{0,11};IEnumerableTup
将一组整数转换为一组范围的最惯用的方法是什么?

例如.给定{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);
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读