>백엔드 개발 >C++ >LINQ를 사용하여 숫자 접미사가 있는 영숫자 문자열을 올바르게 정렬하려면 어떻게 해야 합니까?

LINQ를 사용하여 숫자 접미사가 있는 영숫자 문자열을 올바르게 정렬하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-03 03:47:42744검색

How Can I Sort Alphanumeric Strings with Numeric Suffixes Correctly Using LINQ?

LINQ를 사용한 영숫자 정렬

각 요소가 숫자 값으로 끝나는 영숫자 문자열을 정렬하는 것은 LINQ의 기본 정렬 메커니즘을 사용하면 어려울 수 있습니다. 문제는 알파벳순에만 의존하여 예기치 않은 정렬 출력이 발생하는 경우 발생합니다.

다음 문자열 배열을 고려하세요.

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

LINQ의 OrderBy 메서드를 직접 적용하면 다음과 같이 정렬된 출력이 생성됩니다.

AB1
Ab11
AB2
ABC1
ABC10
ABC10
ABC11
ABC2

이 결과는 끝에 있는 숫자 값이 일치하지 않기 때문에 원하는 기대와 다릅니다.

해결책

의도한 정렬을 달성하려면 정렬 키에서 문자열의 숫자 부분을 채워야 합니다. 이는 다음과 같이 정의된 PadNumbers와 같은 사용자 정의 방법을 사용하여 수행할 수 있습니다.

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

이 방법은 입력 문자열의 모든 숫자 시퀀스를 패딩 처리된 해당 항목으로 바꿉니다. OrderBy 절 내에서 이 방법을 사용하면 비교를 위해 숫자 부분이 효과적으로 정규화됩니다.

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

이 접근 방식을 사용하면 숫자 값이 길이에 관계없이 동일하게 처리되어 원하는 영숫자 정렬이 가능해집니다.

AB1
AB2
AB11
...

이 솔루션은 숫자의 최대 자릿수를 가정하지만 다음을 사용하여 영숫자 정렬을 위한 강력한 방법을 제공합니다. 링크.

위 내용은 LINQ를 사용하여 숫자 접미사가 있는 영숫자 문자열을 올바르게 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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