2020-04-05 19:19:04 +00:00
|
|
|
#nullable enable
|
|
|
|
|
2019-12-06 11:06:13 +00:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
|
|
namespace MediaBrowser.Common.Extensions
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// Provides <c>Shuffle</c> extensions methods for <see cref="IList{T}" />.
|
|
|
|
/// </summary>
|
|
|
|
public static class ShuffleExtensions
|
|
|
|
{
|
|
|
|
private static readonly Random _rng = new Random();
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Shuffles the items in a list.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="list">The list that should get shuffled.</param>
|
|
|
|
/// <typeparam name="T">The type.</typeparam>
|
|
|
|
public static void Shuffle<T>(this IList<T> list)
|
2020-03-04 23:54:46 +00:00
|
|
|
{
|
|
|
|
list.Shuffle(_rng);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Shuffles the items in a list.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="list">The list that should get shuffled.</param>
|
|
|
|
/// <param name="rng">The random number generator to use.</param>
|
|
|
|
/// <typeparam name="T">The type.</typeparam>
|
|
|
|
public static void Shuffle<T>(this IList<T> list, Random rng)
|
2019-12-06 11:06:13 +00:00
|
|
|
{
|
|
|
|
int n = list.Count;
|
|
|
|
while (n > 1)
|
|
|
|
{
|
2021-01-26 19:28:35 +00:00
|
|
|
int k = rng.Next(n--);
|
2019-12-06 11:06:13 +00:00
|
|
|
T value = list[k];
|
|
|
|
list[k] = list[n];
|
|
|
|
list[n] = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|