class Program
{
static void Main(string[] args)
{
int[] i = { 4, 34, 5, 22, 7, 8,3,9,21,23,24 };
List<int> list = i.ToList();
List<List<int>> arr = getContinuousNum(list, true);
Console.WriteLine("可分为以下几个连续段:");
foreach (List<int> item in arr) {
foreach (int j in item) {
Console.Write(j + " ");
}
Console.WriteLine("");
}
}
public static List<List<int>> getContinuousNum(List<int> list, bool isAsc = true)
{
//默认升序排序
if (isAsc)
{
list.Sort((x, y) => x.CompareTo(y));
//list.Sort((x, y) => -x.CompareTo(y)); 降序排序
}
List<List<int>> array = new List<List<int>>();//连续的为一个小数组
List<int> temp = new List<int>(); //临时存放连续的一个数组
for (int i = 0; i < list.Count; i++)
{
//break条件
if (i == list.Count - 2)
{
//每次当前的都放进去
temp.Add(list[i]);
//如果连续的话,就把最后一位也放进去
if (list[i + 1] - list[i] == 1)
{
temp.Add(list[i + 1]);
array.Add(temp);
}
//不连续的话,先把当前数组存了,再单独存放最后一位
else
{
array.Add(temp);
temp = new List<int>();
temp.Add(list[i + 1]);
array.Add(temp);
}
break;
}
//每次都把当前数据丢入临时数组中,如果和下一个数据不连续的话,就把临时数组作为一个段存起来,继续下一个连续段
temp.Add(list[i]);
if (list[i + 1] - list[i] != 1)
{
array.Add(temp);
temp = new List<int>();
}
}
return array;
}
}