>백엔드 개발 >C++ >조회 테이블을 사용하지 않고 정수를 서면 형식으로 효율적으로 변환하려면 어떻게 해야 합니까?

조회 테이블을 사용하지 않고 정수를 서면 형식으로 효율적으로 변환하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-12 20:12:43934검색

How Can I Efficiently Convert Integers to Their Written Forms Without Using Lookup Tables?

조회 테이블 방지: 정수를 단어로 변환하는 효율적인 알고리즘

정수를 단어 표현으로 변환하는 것은 일반적인 프로그래밍 작업입니다. 조회 테이블은 작은 숫자에 대한 간단한 솔루션을 제공하지만 큰 값에 대해서는 다루기가 어려워집니다. 이 문서에서는 대규모 조회 테이블을 사용하지 않는 보다 확장 가능하고 효율적인 방법을 제시합니다.

이 접근 방식의 핵심에는 여러 어레이가 포함됩니다.

  • ones: 한 자리 숫자에 대한 단어를 포함하는 배열(예: "One", "Two", ... "Nine").
  • teens: 11부터 19까지의 단어를 포함하는 배열.
  • tens: 10의 배수에 해당하는 단어를 포함하는 배열(예: "20", "30", ... "90").
  • thousandsGroups: 수천, 수백만, 수십억의 접두사를 포함하는 배열입니다.

알고리즘의 핵심은 세 가지 매개변수를 사용하는 재귀 함수인 FriendlyInteger 함수입니다.

  • n: 변환할 정수입니다.
  • leftDigits: n 왼쪽에 있는 숫자의 단어 표현(재귀에 사용).
  • thousands: 현재 천개 그룹(단위, 천, 백만 등).

FriendlyInteger은 입력 정수를 재귀적으로 분해하여 단어 표현을 하나씩 구축합니다. 예를 들어 1532를 변환하면:

  1. FriendlyInteger(32, "One Thousand", 1): 천 자리를 처리하여 "천"이 됩니다.
  2. FriendlyInteger(32, null, 0): 나머지 32개를 처리합니다.
  3. FriendlyInteger(2, "Thirty", 0): 십의 자리를 처리하여 "Thirty"를 생성합니다.
  4. FriendlyInteger(0, "Two", 0): 단위 숫자를 처리하여 "2"를 생성합니다.
  5. 최종 결과는 "천삼백삼십이"로 연결됩니다.

IntegerToWritten 함수는 진입점 역할을 하며 기본 변환을 위해 FriendlyInteger를 호출하기 전에 0 및 음수와 같은 특수한 경우를 처리합니다.

미리 정의된 배열의 사용과 결합된 이 재귀적 접근 방식은 광범위한 조회 테이블 없이 정수를 작성된 형식으로 변환하기 위한 효율적이고 확장 가능한 솔루션을 제공하므로 광범위한 숫자 입력을 처리하는 데 적합합니다.

위 내용은 조회 테이블을 사용하지 않고 정수를 서면 형식으로 효율적으로 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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