「C♯で配列やコレクションをシャッフルする」を編集中

ナビゲーションに移動 検索に移動

警告: ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。ログインまたはアカウントを作成すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。

この編集を取り消せます。 下記の差分を確認して、本当に取り消していいか検証してください。よろしければ変更を保存して取り消しを完了してください。

最新版 編集中の文章
3行目: 3行目:
 
[[ググる]]と出てきた[[LINQ]]使ったやつ。
 
[[ググる]]と出てきた[[LINQ]]使ったやつ。
 
<source lang="csharp">
 
<source lang="csharp">
    using System;
 
    using System.Collections.Generic;
 
    using System.Linq;
 
 
 
     public static class IEnumerableExtension
 
     public static class IEnumerableExtension
 
     {
 
     {
16行目: 12行目:
 
</source>
 
</source>
  
 
+
乱数生成器が指定できたほうがよくね?Randomクラスはアルゴリズムがよろしくないらしいが、シールドクラスではないのでメルセンヌ・ツイスタあたりを実装すればいい。
乱数生成器が指定できたほうがよくね?Randomクラスは[[アルゴリズム]]がよろしくないらしいが、シールドクラスではないのでメルセンヌ・ツイスタあたりを実装すればいい。
 
 
* [[C♯でメルセンヌ・ツイスタ乱数]]
 
* [[C♯でメルセンヌ・ツイスタ乱数]]
 
<source lang="csharp">
 
<source lang="csharp">
    using System;
+
     public static class IEnumerableExtensions
    using System.Collections.Generic;
 
    using System.Linq;
 
 
 
     public static class IEnumerableExtension
 
 
     {
 
     {
         public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> collection, Random random)
+
         public static IEnumerable<TSource> Shuffle<TSource>(this IEnumerable<TSource> source, Random random)
 
         {
 
         {
             return collection.OrderBy(i => random.Next());
+
             var copy = source.ToList();
 +
 
 +
            int count = 0;
 +
            while (0 < (count = copy.Count))
 +
            {
 +
                int index = random.Next(count);
 +
                yield return copy[index];
 +
                copy.RemoveAt(index);
 +
            }
 
         }
 
         }
  

MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細はMonoBook:著作権を参照)。 著作権保護されている作品は、許諾なしに投稿しないでください!

このページを編集するには、下記の確認用の質問に回答してください (詳細):

取り消し 編集の仕方 (新しいウィンドウで開きます)