首頁 後端開發 C++ 在沒有大量查找表的情況下,如何將整數有效地轉換為其書面形式?

在沒有大量查找表的情況下,如何將整數有效地轉換為其書面形式?

Jan 12, 2025 pm 08:13 PM

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

高效率的整數到文字的轉換方法

問題:

如何有效地將整數轉換為其文字形式?例如:

1

<code>string 文字形式 = 整数转文字(21);</code>

登入後複製

應該輸出 "Twenty One"。

是否存在一種方法可以不依賴大量的查找表?

答案:

以下解決方案提供了一個實用方法:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

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 &gt; 0)

        {

            friendlyInt += " ";

        }

 

        if (n &lt; 100)

        {

            if (n &lt; 20)

            {

                friendlyInt += teens[n - 10];

            }

            else

            {

                friendlyInt += tens[(n / 10) - 2];

                if (n % 10 &gt; 0)

                {

                    friendlyInt += " " + ones[n % 10];

                }

            }

        }

        else

        {

            friendlyInt += ones[n / 100] + " Hundred";

            if (n % 100 &gt; 0)

            {

                friendlyInt += " " + FriendlyInteger(n % 100, "", 0);

            }

        }

 

        return friendlyInt + thousandsGroups[thousands];

    }

 

    public static string IntegerToWritten(int n)

    {

        if (n == 0) return "Zero";

        if (n &lt; 0) return "Minus " + IntegerToWritten(-n);

 

        string result = "";

        int thousands = 0;

 

        while (n &gt; 0)

        {

            result = FriendlyInteger(n % 1000, result, thousands) + result;

            n /= 1000;

            thousands++;

        }

 

        return result.Trim();

    }

}

登入後複製

此方法避免了使用大型查找表。相反,它將整數分解成不同的部分(千位、百位、十位、個位),並分別轉換每一部分。它支援高達數十億的數字。

以上是在沒有大量查找表的情況下,如何將整數有效地轉換為其書面形式?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

See all articles