【发布时间】:2020-12-14 23:57:33
【问题描述】:
免责声明:A very similar question was already asked in a Python context here. 这是关于 C# 的。
我有一个包含整数的枚举,例如:
[1, 2, 3, 4, 7, 8, 10, 11, 12, 13, 14]
我想获得一个字符串,输出连续整数的范围:
1-4, 7-8, 10-14
我想出了:
public static void Main()
{
System.Diagnostics.Debug.WriteLine(FindConsecutiveNumbers(new int[] { 1,2, 7,8,9, 12, 15, 20,21 }));
}
private static string FindConsecutiveNumbers(IEnumerable<int> numbers)
{
var sb = new StringBuilder();
int? start = null;
int? lastNumber = null;
const string s = ", ";
const string c = "-";
var numbersPlusIntMax = numbers.ToList();
numbersPlusIntMax.Add(int.MaxValue);
foreach (var number in numbersPlusIntMax)
{
var isConsecutive = lastNumber != null && lastNumber + 1 == number;
if (!isConsecutive)
{
if (start != null)
{
if (sb.Length > 0) { sb.Append(s); }
if (start == lastNumber)
{
sb.Append(start); ;
}
else
{
sb.Append(start + c + lastNumber); ;
}
}
start = number;
}
lastNumber = number;
}
return sb.ToString();
}
此算法适用于有序输入。是否有内置/LINQ/更短的 C# 方式来执行此操作?
【问题讨论】: