X

C#でプロジェクトオイラーを解く(問題17「数字の文字数」)

どーも、みつおです。

英単語の定義がめんどくさい問題だった。

問題

1 から 5 までの数字を英単語で書けば one, two, three, four, five であり, 全部で 3 + 3 + 5 + 4 + 4 = 19 の文字が使われている.

では 1 から 1000 (one thousand) までの数字をすべて英単語で書けば, 全部で何文字になるか.

: 空白文字やハイフンを数えないこと. 例えば, 342 (three hundred and forty-two) は 23 文字, 115 (one hundred and fifteen) は20文字と数える. なお, “and” を使用するのは英国の慣習.

出典:Problem17

解答

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Problem17
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine(Solve());
            Console.ReadLine();
        }

        private static int Solve()
        {
            int ret = 0;

            List<Number> numlist = new List<Number>();

            //1000までの数値と英単語を取得
            for (int i = 1; i <= 1000; i++)
            {
                Number num = new Number(i);
                numlist.Add(num);
            }

            //英単語の文字を足し合わせる
            foreach (var tmp in numlist)
            {
                ret += tmp.English.Length;
            }

            return ret;
        }
    }

    public class Number
    {
        #region プロパティ
        public int No { set; get; }

        public string English { set; get; }
        #endregion

        #region コンストラクタ
        public Number()
        {
            No = 0;
            English = "";
        }
        public Number(int no)
        {
            this.No = no;
            this.English = GetEnglish();
        }
        #endregion

        #region メソッド
        /// <summary>
        /// 数字を英単語に変換
        /// </summary>
        /// <returns></returns>
        public string GetEnglish()
        {
            string ret = "";
            int point = 0;

            string[] one = new string[] { "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen" };
            string[] ten = new string[] { "twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety" };
            string[] hyaku = new string[] { "hundred", "thousand" };
            string and = "and";

            point = this.No;
            while (point != 0)
            {
                if (1 <= point && point <= 19)
                {
                    ret += one[point - 1];
                    point = 0;
                }
                else if (20 <= point && point <= 29)
                {
                    ret += ten[0];
                    point = point - 20;
                }
                else if (30 <= point && point <= 39)
                {
                    ret += ten[1];
                    point = point - 30;
                }
                else if (40 <= point && point <= 49)
                {
                    ret += ten[2];
                    point = point - 40;
                }
                else if (50 <= point && point <= 59)
                {
                    ret += ten[3];
                    point = point - 50;
                }
                else if (60 <= point && point <= 69)
                {
                    ret += ten[4];
                    point = point - 60;
                }
                else if (70 <= point && point <= 79)
                {
                    ret += ten[5];
                    point = point - 70;
                }
                else if (80 <= point && point <= 89)
                {
                    ret += ten[6];
                    point = point - 80;
                }
                else if (90 <= point && point <= 99)
                {
                    ret += ten[7];
                    point = point - 90;
                }
                else if (100 <= point && point <= 199)
                {
                    ret += one[0];
                    ret += hyaku[0];
                    point = point - 100;
                    if (point != 0) ret += and;
                }
                else if (200 <= point && point <= 299)
                {
                    ret += one[1];
                    ret += hyaku[0];
                    point = point - 200;
                    if (point != 0) ret += and;
                }
                else if (300 <= point && point <= 399)
                {
                    ret += one[2];
                    ret += hyaku[0];
                    point = point - 300;
                    if (point != 0) ret += and;
                }
                else if (400 <= point && point <= 499)
                {
                    ret += one[3];
                    ret += hyaku[0];
                    point = point - 400;
                    if (point != 0) ret += and;
                }
                else if (500 <= point && point <= 599)
                {
                    ret += one[4];
                    ret += hyaku[0];
                    point = point - 500;
                    if (point != 0) ret += and;
                }
                else if (600 <= point && point <= 699)
                {
                    ret += one[5];
                    ret += hyaku[0];
                    point = point - 600;
                    if (point != 0) ret += and;
                }
                else if (700 <= point && point <= 799)
                {
                    ret += one[6];
                    ret += hyaku[0];
                    point = point - 700;
                    if (point != 0) ret += and;
                }
                else if (800 <= point && point <= 899)
                {
                    ret += one[7];
                    ret += hyaku[0];
                    point = point - 800;
                    if (point != 0) ret += and;
                }
                else if (900 <= point && point <= 999)
                {
                    ret += one[8];
                    ret += hyaku[0];
                    point = point - 900;
                    if (point != 0) ret += and;
                }
                else if (1000 <= point && point <= 1999)
                {
                    ret += one[0];
                    ret += hyaku[1];
                    point = point - 1000;
                    if (point != 0) ret += and;
                }
            }

            return ret;
        }
        #endregion
    }
}

出力

21124

みつお: