Maison > développement back-end > C++ > Comment puis-je mélanger efficacement une liste générique en C #?

Comment puis-je mélanger efficacement une liste générique en C #?

Mary-Kate Olsen
Libérer: 2025-02-03 07:58:13
original
1042 Les gens l'ont consulté

La méthode de mélange efficace de la liste générique des génériques

Dans divers scénarios de programmation, l'ordre des éléments dans des listes génériques aléatoires est une opération courante. Cet article présentera la meilleure façon d'atteindre cet objectif en C #.

Fisher-Yates Shuffle Algorithme Implementation

La méthode la plus recommandée consiste à utiliser l'algorithme Shuffle Fisher-Yates, qui est un algorithme de randomisation de liste bien connu. Pour utiliser cette méthode, veuillez définir une méthode d'extension, comme indiqué ci-dessous:

public static void Shuffle<T>(this IList<T> list)  
{  
    int n = list.Count;  
    while (n > 1) {  
        n--;  
        int k = rng.Next(n + 1);  
        T value = list[k];  
        list[k] = list[n];  
        list[n] = value;  
    }  
}
Copier après la connexion

<方法> comment utiliser:

List<Product> products = GetProducts();
products.Shuffle();
Copier après la connexion
Utilisation de System.Security.Cryptographie pour améliorer le hasard

Bien que <率> efficace élevée, il peut ne pas être en mesure de générer une véritable séquence aléatoire. Afin d'améliorer le hasard, <> la bibliothèque offre une option plus fiable:

System.Random System.Security.Cryptography Considérations de sécurité des threads

public static void Shuffle<T>(this IList<T> list)
{
    using (RNGCryptoServiceProvider provider = new RNGCryptoServiceProvider())
    {
        int n = list.Count;
        while (n > 1)
        {
            byte[] box = new byte[1];
            do provider.GetBytes(box);
            while (!(box[0] < (byte)((double)n / 256))); //确保生成的随机数在范围内
            int k = (int)(box[0] * (n / 256.0));
            T value = list[k];
            list[k] = list[n - 1];
            list[n - 1] = value;
            n--;
        }
    }
}
Copier après la connexion
Lors de l'utilisation de la méthode d'extension Shuffle dans des applications multi-thread, il est nécessaire d'assurer la sécurité des threads. Une solution simple consiste à créer un nouvel exemple de

:

ThreadSafeRandom La méthode d'extension mise à jour

public static class ThreadSafeRandom
{
    [ThreadStatic] private static Random Local;

    public static Random ThisThreadsRandom
    {
        get { return Local ?? (Local = new Random(unchecked(Environment.TickCount * 31 + Thread.CurrentThread.ManagedThreadId))); }
    }
}
Copier après la connexion
Intégrez la méthode de sécurité du thread à la méthode d'extension Shuffle:

<<>
public static void Shuffle<T>(this IList<T> list)
{
    int n = list.Count;
    while (n > 1)
    {
        n--;
        int k = ThreadSafeRandom.ThisThreadsRandom.Next(n + 1);
        T value = list[k];
        list[k] = list[n];
        list[n] = value;
    }
}
Copier après la connexion
Cette réponse révisée fournit au cacheterrererereRanPlanations, améliore la lisibilité du code (en particulier l'examph de RNGCryprovider) et répond plus efficacement aux préoccupations de sécurité.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal