将一组整数转换为一组范围的最惯用的方法是什么?
例如.给定{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); }