>백엔드 개발 >C++ >LINQ는 숫자가 포함된 문자열의 올바른 영숫자 정렬을 어떻게 달성할 수 있습니까?

LINQ는 숫자가 포함된 문자열의 올바른 영숫자 정렬을 어떻게 달성할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-29 06:59:15946검색

How Can LINQ Achieve Correct Alphanumeric Sorting of Strings Containing Numbers?

LINQ를 사용한 영숫자 정렬

숫자 값이 포함된 문자열을 처리할 때 LINQ의 기본 알파벳 정렬로는 원하는 결과가 나오지 않을 수 있습니다. 다음 예를 고려하십시오.

string[] partNumbers = new string[] 
{ 
    "ABC10", "ABC1","ABC2", "ABC11","ABC10", "AB1", "AB2", "Ab11" 
};

var result = partNumbers.OrderBy(x => x);

예상 결과는 다음과 같이 문자열을 정렬합니다.

AB1
AB2
AB11
...

그러나 기본 문자열 순서는 사전식 순서를 따르기 때문에 실제 결과는 다릅니다. 이는 숫자 값이 왼쪽에서 오른쪽으로 비교되어 다음 순서로 이어진다는 것을 의미합니다.

AB1
Ab11
AB2
ABC1
ABC10
ABC10
ABC11
ABC2

원하는 영숫자 정렬을 달성하려면 비교 논리를 수정해야 합니다. 각 문자열의 숫자 부분을 특정 개수의 0으로 채울 수 있습니다. 이렇게 하면 길이에 관계없이 숫자 값이 공정하게 비교됩니다.

public static string PadNumbers(string input)
{
    return Regex.Replace(input, "[0-9]+", match => match.Value.PadLeft(10, '0'));
}

var result = partNumbers.OrderBy(x => PadNumbers(x));

이 수정된 순서를 사용하면 문자열의 숫자 부분이 패딩된 값을 기준으로 비교되어 다음과 같은 올바른 순서가 적용됩니다.

AB1
AB2
AB11
...

이 접근 방식에서는 입력 숫자의 최대 자릿수를 가정합니다. 지정된 패딩보다 자릿수가 많은 숫자가 있는 경우 정렬이 정확하지 않을 수 있습니다.

위 내용은 LINQ는 숫자가 포함된 문자열의 올바른 영숫자 정렬을 어떻게 달성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.