我需要对 64 位整数进行操作。我试图将 36 的结果提高到 12 的幂作为练习(并且作为要求)。
我在我的 VS2008 编译器上使用了 unsigned long long 作为 64 位整数。我已经编写了下面的代码,有人可以向我解释一下,为什么我的 for 循环版本会产生不正确的结果,而我的递归版本的 Power 函数会产生正确的结果?
仅供参考: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" );
}