ホームページ >バックエンド開発 >C++ >C# で整数配列を効率的にシャッフルするにはどうすればよいですか?

C# で整数配列を効率的にシャッフルするにはどうすればよいですか?

DDD
DDDオリジナル
2025-01-21 14:11:11154ブラウズ

How Can I Efficiently Shuffle an Integer Array in C#?

C# での整数配列シャッフルの最適化

C# で整数配列を効率的にランダムにシャッフルするために、Fisher-Yates アルゴリズムは線形時間ソリューションを提供します。 代替アプローチは、特にシャッフルが完了に近づくにつれて、パフォーマンスのボトルネックに遭遇する可能性があります。

フィッシャー・イェーツのシャッフルは、単純かつ効果的な方法を採用することでこれらの問題を回避します。

  1. 配列の未ソート部分からランダムなインデックスが選択されます。
  2. 現在のインデックスの要素は、ランダムに選択されたインデックスの要素と交換されます。
  3. 現在のインデックスがインクリメントされ、配列全体が処理されるまでステップ 1 と 2 が繰り返されます。

これにより、O(n) 時間で均一にランダムなシャッフルが保証され、整数配列をランダム化する信頼性の高い効率的な方法が提供されます。

以上がC# で整数配列を効率的にシャッフルするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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