Выборка LINQ. Получить самую длинную группу возрастающих чисел - C#

Узнай цену своей работы

Формулировка задачи:

Всем привет! Есть массив чисел int[]{0, 3, 5, 4, 12, 9, 8} Как с помощью LINQ получить группу чисел идущих по порядку - (3, 4, 5, 8, 9), а затем выбрать группу чисел в которой чисел последовательности больше, т.е (3, 4, 5) > (8, 9) В результате нужно получить массив {3, 4, 5} Надеюсь на Вашу помощь!

Решение задачи: «Выборка LINQ. Получить самую длинную группу возрастающих чисел»

textual
Листинг программы
  1.             int[] num = { 0, 3, 5, 4, 12, 9, 8, 6, -1, 13, 14, 15, 3, 4, 5, 6 };
  2.  
  3.             var a = num.Distinct()
  4.                 .OrderBy(n => n)
  5.                 .Select((n, i) => new { n = n, i = n - i })
  6.                 .GroupBy(n => n.i)
  7.  
  8.                 .Max(g => Tuple.Create(g.Count(), -g.First().n, g.Select(n => n.n))).Item3;
  9.  
  10.             Console.WriteLine(string.Join(" ", a));
  11.             Console.ReadKey();

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

11   голосов , оценка 3.909 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы