X

C#でプロジェクトオイラーを解く(問題29「個別のべき乗」)

どーも、みつおです。

問題

2 ≤ a ≤ 5 と 2 ≤ b ≤ 5について, ab を全て考えてみよう:

  • 2^2=4, 2^3=8, 2^4=16, 2^5=32
  • 3^2=9, 3^3=27, 3^4=81, 3^5=243
  • 4^2=16, 4^3=64, 4^4=256, 4^5=1024
  • 5^2=25, 5^3=125, 5^4=625, 5^5=3125

これらを小さい順に並べ, 同じ数を除いたとすると, 15個の項を得る:

4, 8, 9, 16, 25, 27, 32, 64, 81, 125, 243, 256, 625, 1024, 3125

2 ≤ a ≤ 100, 2 ≤ b ≤ 100 で同じことをしたときいくつの異なる項が存在するか?

出典:Problem29

解答

using System;
using System.Collections.Generic;
using System.Linq;
using System.Numerics;

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

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

            List<BigInteger> list = new List<BigInteger>();

            for (int a = 2; a <= 100; a++)
            {
                for (int b = 2; b <= 100; b++)
                {
                    //a^bを求める
                    BigInteger tmp = BigInteger.Pow(a, b);
                    list.Add(tmp);
                }
            }

            //重複削除
            var dlist = list.Distinct();

            //項を数える
            ret = dlist.Count();

            return ret;
        }
    }
}

 

出力

9183

みつお: