64 ビット整数を操作する必要があります。演習として (および要件として) 36 を 12 乗した結果を取得しようとしています。
VS2008 コンパイラで 64 ビット整数に unsigned long long を使用しました。以下のコードを作成しましたが、Power 関数の再帰バージョンでは正しい結果が生成されるのに、for ループ バージョンでは誤った結果が生成されるのはなぜですか?
参考までに: 36 を 12 に上げると、4738381338321616896 になります。
template< typename _T1, typename _T2 >
_T1 Power( _T1 p_base, _T2 p_power )
{
/*
// This produces 0?!!
if( p_power == 0 ) return 1;
for( _T2 i = 1; i < p_power; ++i )
{
p_base *= p_base;
}
return p_base;
*/
// This produces correct result.
if( p_power == 0 ) return 1;
if( p_power == 1 ) return p_base;
return p_base * Power( p_base, p_power - 1 );
}
void main( int argc, char * argv[] )
{
unsigned long long charsetSize = 36LL;
printf( "Maximum Keys: %llu\n\n", Power( charsetSize, 12 ) );
system( "pause" );
}