Пожалуйста, предложите самый простой способ получить случайную перетасованную коллекцию count 'n' из коллекции, имеющей элементы "N". где n <= N
Оптимальный запрос LINQ для получения случайной подпапки - Shuffle
Ответ 1
Другим вариантом является использование OrderBy и сортировка по значению GUID, которое вы можете сделать, используя:
var result = sequence.OrderBy(elem => Guid.NewGuid());
Я сделал некоторые эмпирические тесты, чтобы убедить себя, что вышеупомянутое фактически порождает случайное распределение (которое, по-видимому, оно делает). Вы можете увидеть мои результаты в Методы случайного переупорядочения массива.
Ответ 2
В дополнение к комментарию mquander и комментатору Dan Blanchard, здесь используется метод расширения LINQ, который выполняет Fisher-Yates-Durstenfeld shuffle:
// take n random items from yourCollection
var randomItems = yourCollection.Shuffle().Take(n);
// ...
public static class EnumerableExtensions
{
    public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> source)
    {
        return source.Shuffle(new Random());
    }
    public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> source, Random rng)
    {
        if (source == null) throw new ArgumentNullException("source");
        if (rng == null) throw new ArgumentNullException("rng");
        return source.ShuffleIterator(rng);
    }
    private static IEnumerable<T> ShuffleIterator<T>(
        this IEnumerable<T> source, Random rng)
    {
        var buffer = source.ToList();
        for (int i = 0; i < buffer.Count; i++)
        {
            int j = rng.Next(i, buffer.Count);
            yield return buffer[j];
            buffer[j] = buffer[i];
        }
    }
}
Ответ 3
У этого есть некоторые проблемы со "случайным уклоном", и я уверен, что это не оптимально, это еще одна возможность:
var r = new Random();
l.OrderBy(x => r.NextDouble()).Take(n);
Ответ 4
 Shuffle сбор в случайный порядок и вывести первые n элементы из результата.
Ответ 5
бит менее случайный, но эффективный:
var rnd = new Random();
var toSkip = list.Count()-n;
if (toSkip > 0)
    toSkip = rnd.Next(toSkip);
else
    toSkip=0;
var randomlySelectedSequence = list.Skip(toSkip).Take(n);
Ответ 6
Я пишу этот метод переопределения:
public static IEnumerable<T> Randomize<T>(this IEnumerable<T> items) where T : class
{
     int max = items.Count();
     var secuencia = Enumerable.Range(1, max).OrderBy(n => n * n * (new Random()).Next());
     return ListOrder<T>(items, secuencia.ToArray());
}
private static IEnumerable<T> ListOrder<T>(IEnumerable<T> items, int[] secuencia) where T : class
        {
            List<T> newList = new List<T>();
            int count = 0;
            foreach (var seed in count > 0 ? secuencia.Skip(1) : secuencia.Skip(0))
            {
                newList.Add(items.ElementAt(seed - 1));
                count++;
            }
            return newList.AsEnumerable<T>();
        }
Затем у меня есть список источников (все элементы)
var listSource = p.Session.QueryOver<Listado>(() => pl)
                        .Where(...);
Наконец, я называю "Randomize", и я получаю случайную подсерию элементов, в моем случае, 5 элементов:
var SubCollection = Randomize(listSource.List()).Take(5).ToList();
Ответ 7
Извините за уродливый код:-), но
var result =yourCollection.OrderBy(p => (p.GetHashCode().ToString() + Guid.NewGuid().ToString()).GetHashCode()).Take(n);
