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

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

Mary-Kate Olsen
リリース: 2025-01-01 03:54:09
オリジナル
978 人が閲覧しました

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート