У меня есть список диапазонов, и я хотел бы узнать, перекрываются ли они.Перекрывающиеся диапазоны Проверка на перекрытие
У меня есть следующий код. Кажется, что это не работает. Есть ли более простой способ сделать это или способ, который работает :)
Заранее благодарим за любые советы.
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