我有一個範圍列表,我想知道它們是否重疊。重疊範圍檢查重疊
我有以下代碼。這似乎沒有工作。有沒有一個更簡單的方法來做到這一點或作品:)
在此先感謝您的任何建議。
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; }
}
感覺這應該是一個新的問題,而不是現有的賞金。隨着時間的推移,Stack Overflow並不能很好地解決問題 - 對於那些回答最初問題的人來說,這是不公平的,因爲後來的任何人都會認爲他們錯過了這一點。 (另外,我不知道其他人,但我不明白在賞金規定的要求...) –
除了提交的答案,我認爲你可能會對你描述的問題基本上是一個事實感興趣「線段交點」問題的實例,最常用「掃描線算法」解決。也許更多地閱讀它可以爲您的進一步問題提供答案。 – Grx70