> 백엔드 개발 > C++ > 광범위한 조회 테이블 없이 어떻게 정수를 서면 형식으로 효율적으로 변환할 수 있습니까?

광범위한 조회 테이블 없이 어떻게 정수를 서면 형식으로 효율적으로 변환할 수 있습니까?

DDD
풀어 주다: 2025-01-12 20:13:43
원래의
944명이 탐색했습니다.

How Can Integers Be Efficiently Converted to Their Written Forms Without Extensive Lookup Tables?

효율적인 정수를 텍스트로 변환하는 방법

질문:

정수를 리터럴 형식으로 효율적으로 변환하는 방법은 무엇입니까? 예:

<code>string 文字形式 = 整数转文字(21);</code>
로그인 후 복사

"Twenty One"을 출력해야 합니다.

대량 조회 테이블에 의존하지 않고 이를 수행할 수 있는 방법이 있나요?

정답:

다음 솔루션은 실용적인 접근 방식을 제공합니다.

<code class="language-c#">public static class HumanFriendlyInteger
{
    static string[] ones = new string[] { "", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine" };
    static string[] teens = new string[] { "Ten", "Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", "Nineteen" };
    static string[] tens = new string[] { "Twenty", "Thirty", "Forty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety" };
    static string[] thousandsGroups = { "", " Thousand", " Million", " Billion" };

    private static string FriendlyInteger(int n, string leftDigits, int thousands)
    {
        if (n == 0)
        {
            return leftDigits;
        }

        string friendlyInt = leftDigits;

        if (friendlyInt.Length > 0)
        {
            friendlyInt += " ";
        }

        if (n < 100)
        {
            if (n < 20)
            {
                friendlyInt += teens[n - 10];
            }
            else
            {
                friendlyInt += tens[(n / 10) - 2];
                if (n % 10 > 0)
                {
                    friendlyInt += " " + ones[n % 10];
                }
            }
        }
        else
        {
            friendlyInt += ones[n / 100] + " Hundred";
            if (n % 100 > 0)
            {
                friendlyInt += " " + FriendlyInteger(n % 100, "", 0);
            }
        }

        return friendlyInt + thousandsGroups[thousands];
    }

    public static string IntegerToWritten(int n)
    {
        if (n == 0) return "Zero";
        if (n < 0) return "Minus " + IntegerToWritten(-n);

        string result = "";
        int thousands = 0;

        while (n > 0)
        {
            result = FriendlyInteger(n % 1000, result, thousands) + result;
            n /= 1000;
            thousands++;
        }

        return result.Trim();
    }
}</code>
로그인 후 복사

이 방법을 사용하면 큰 조회 테이블을 사용하지 않아도 됩니다. 대신 정수를 여러 부분(천, 백, 십, 일)으로 나누고 각 부분을 별도로 변환합니다. 최대 수십억 개의 숫자를 지원합니다.

위 내용은 광범위한 조회 테이블 없이 어떻게 정수를 서면 형식으로 효율적으로 변환할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿