Maison >développement back-end >C++ >Comment puis-je réaliser un classement alphanumérique dans LINQ avec des suffixes numériques ?
Ordre alphanumérique dans LINQ
Dans LINQ, la méthode OrderBy suit la règle de classement lexicographique, qui considère les caractères alphabétiques et numériques dans l'ordre. Cependant, lors du tri de chaînes se terminant par des valeurs numériques, cet ordre peut ne pas produire le résultat souhaité.
Considérez l'exemple suivant :
string[] partNumbers = { "ABC10", "ABC1", "ABC2", "ABC11", "ABC10", "AB1", "AB2", "Ab11" }; var result = partNumbers.OrderBy(x => x);
Le résultat réel, selon l'ordre lexicographique, sera :
AB1 Ab11 AB2 ABC1 ABC10 ABC10 ABC11 ABC2
Cependant, le résultat attendu est de regrouper les séquences alphabétiques similaires, quel que soit le suffixe numérique. Pour y parvenir, nous devons modifier les critères de classement.
La clé du tri alphanumérique est de comparer la partie numérique complétée. En ajoutant des zéros aux valeurs numériques, nous garantissons que LINQ peut les distinguer correctement. Voici comment procéder :
public static string PadNumbers(string input) { return Regex.Replace(input, "[0-9]+", match => match.Value.PadLeft(10, '0')); }
Cette fonction ajoute des zéros à tous les nombres contenus dans la chaîne d'entrée. En utilisant cette fonction comme critère de classement dans LINQ, nous obtenons le résultat attendu :
var result = partNumbers.OrderBy(x => PadNumbers(x));
La liste résultante sera désormais classée comme :
AB1 AB2 AB11 ...
Cette approche suppose que le maximum le nombre de chiffres dans la partie numérique est connu. Pour les cas plus complexes, envisagez d'implémenter un IComparer personnalisé, qui permet un contrôle plus précis des critères de comparaison.
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!