ホームページ >バックエンド開発 >C++ >LINQ を使用してランダムなサブコレクションを効率的に生成するにはどうすればよいですか?

LINQ を使用してランダムなサブコレクションを効率的に生成するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-01 03:54:09984ブラウズ

How to Efficiently Generate Random Subcollections Using LINQ?

ランダムなサブコレクションに対する最適な LINQ クエリ: シャッフル

より大きなコレクションから特定の数のランダムにシャッフルされたコレクションを生成することは、複数の方法で実現できます。 LINQ を使用します。

効率的なアプローチの 1 つは、 Fisher-Yates-Durstenfeld シャッフル アルゴリズム。LINQ の拡張メソッドとして実装できます。

public static class EnumerableExtensions
{
    public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> source, Random rng)
    {
        if (source == null) throw new ArgumentNullException(nameof(source));
        if (rng == null) throw new ArgumentNullException(nameof(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];
        }
    }
}

「N」項目のコレクションからカウント「n」のランダムなサブコレクションを取得するには、n < を使用します。 ;= N、単純に Shuffle() 拡張メソッドを適用し、続いて Take(n):

var randomItems = yourCollection.Shuffle().Take(n);

以上がLINQ を使用してランダムなサブコレクションを効率的に生成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。