c# - 重叠范围 检查重叠

标签 c# .net list range intersect

我有一个范围列表,我想知道它们是否重叠。

我有以下代码。这似乎不起作用。有没有更简单的方法或有效的方法:)

提前感谢您的任何建议。

   public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }

    private IList<Range> rangeList;

    private void Form1_Load(object sender, EventArgs e)
    {
        rangeList.Add(new Range{FromNumber = 0, ToNumber = 100});
        rangeList.Add(new Range { FromNumber = 101, ToNumber = 200 });

        // this range should over lap and throw an exception 
        rangeList.Add(new Range { FromNumber = 199, ToNumber = 300 });

    }

    private bool RangesOverlap()
    {
        var bigList = new List<List<int>>();

        foreach (var range in this.rangeList)
        {
            bigList.Add(new List<int> { range.FromNumber , range.ToNumber });
        }

        IEnumerable<IEnumerable<int>> lists = bigList;

        return lists
         .Where(c => c != null && c.Any())
         .Aggregate(Enumerable.Intersect)
         .ToList().Count > 0;
    }
}


public class Range
{
    public int FromNumber { get; set; }
    public int ToNumber { get; set; }
}

最佳答案

首先合并数字,然后检查生成的列表是否按排序顺序:

rangeList
.OrderBy(p => p.FromNumber)
.Select(p => new[] { p.FromNumber, p.ToNumber })
.SelectMany(p => p)
.Aggregate((p, q) => q >= p ? q : int.MaxValue) == int.MaxValue

关于c# - 重叠范围 检查重叠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21597179/

相关文章:

c# - 正则表达式匹配挂起我的程序

c# - 如何在 C#/.NET 中捕获二进制进程输出

Python-获取列表中少数类的百分比

python - 有什么办法可以缩短这个列表的理解力吗?

python - 将全局列表附加到全局列表?

c# - 如何使用 post 变量进行重定向

c# - JSON反序列化可变数量的属性

c# - 如何在 C# 中有效地获取字节数组的子集(前 N 个元素)?

c# - 为什么这个看似正确的 .NET 代码不能编译?

c# - Visual Studio 2008 断点可见样式