栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

有什么好的通用算法可以折叠一组可能重叠的范围?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

有什么好的通用算法可以折叠一组可能重叠的范围?

这似乎可行并且很容易理解。

    public static IEnumerable<Range<T>> Collapse<T>(this IEnumerable<Range<T>> me, IComparer<T> comparer)    {        List<Range<T>> orderdList = me.OrderBy(r => r.Start).ToList();        List<Range<T>> newList = new List<Range<T>>();        T max = orderdList[0].End;        T min = orderdList[0].Start;        foreach (var item in orderdList.Skip(1))        { if (comparer.Compare(item.End, max) > 0 && comparer.Compare(item.Start, max) > 0) {     newList.Add(new Range<T> { Start = min, End = max });     min = item.Start; } max = comparer.Compare(max, item.End) > 0 ? max : item.End;        }        newList.Add(new Range<T>{Start=min,End=max});        return newList;    }

这是我在评论中提到的变体。基本上是同一回事,但是要进行一些检查和得出结果,而不是在返回之前将其收集在列表中。

    public static IEnumerable<Range<T>> Collapse<T>(this IEnumerable<Range<T>> ranges, IComparer<T> comparer)    {        if(ranges == null || !ranges.Any()) yield break;        if (comparer == null) comparer = Comparer<T>.Default;        var orderdList = ranges.OrderBy(r => r.Start);        var firstRange = orderdList.First();        T min = firstRange.Start;        T max = firstRange.End;        foreach (var current in orderdList.Skip(1))        { if (comparer.Compare(current.End, max) > 0 && comparer.Compare(current.Start, max) > 0) {     yield return Create(min, max);     min = current.Start; } max = comparer.Compare(max, current.End) > 0 ? max : current.End;        }        yield return Create(min, max);    }


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/637444.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号