Não tenho ideia do número de vezes que escrevi uma função para retornar os valores mínimo e máximo de uma sequência.
Eu simplesmente adoro a ideia de como consigo fazer isso agora em C#.
public static class EnumerableExtensions
{
public static (T min, T max) MinMax<T>(this IEnumerable<T> source)
where T : IComparable<T>
{
using (var iterator = source.GetEnumerator())
{
if (!iterator.MoveNext())
{
throw new InvalidOperationException("Cannot find min/max of an empty sequence.");
}
var result = (min: iterator.Current, max: iterator.Current);
while (iterator.MoveNext())
{
if (iterator.Current.CompareTo(result.min) < 0) result.min = iterator.Current;
if (iterator.Current.CompareTo(result.max) > 0) result.max = iterator.Current;
}
return result;
}
}
}
Pretty nice, right?!
class Program
{
static void Main(string[] args)
{
var sequence = Enumerable.Range(10, 1000000);
var minmax = sequence.MinMax();
Console.WriteLine($"Min: {minmax.min} Max: {minmax.max}");
}
}
That’s it.