c言語のmまたはnが13以上となる場合に正しい解を求めることができない、なぜなら、13の階乗は6,227,020,800であり、この値はint型変数で扱うことのできる範囲をこえてしまっているからである。以下のプログラムを改良しなるべく大きなmやnの値でも正しく解を求めることができるプログラムをおしえてください。しかし、変数はあくまでint型を用い、floatやdouble型は使用しない方法でお願いします
int add( int a, int b )
{
int i;
int d = ( b>0 ? 1 : -1 );
int n = ( b>0 ? b : -b );
for( i=0; i<n; ++i )
{ a += d; }
return a;
}
int mul( int a, int b )
{
int i;
int r = 0;
int n = ( b>0 ? b : -b );
for( i=0; i<n; ++i )
{ r = add( r, a ); }
return ( b>0 ? r : -r );
}
int fn( int kitten )
{
return ( kitten>1 ? mul( kitten, fn(kitten-1) ) : 1 );
}
C言語
Re: C言語
複雑な問題?マシンの性能を上げてOpenMPで殴ればいい!(死亡フラグ)
Re: C言語
懲りませんね。
「c言語のmまたはnが13以上となる場合に正しい…」
https://detail.chiebukuro.yahoo.co.jp/q ... 2176210307
「c言語のmまたはnが13以上となる場合に正しい解を求めることができない、なぜなら、13の階乗は6,2」
https://oshiete.goo.ne.jp/qa/9824288.html
「c言語のmまたはnが13以上となる場合に正しい…」
https://detail.chiebukuro.yahoo.co.jp/q ... 2176210307
「c言語のmまたはnが13以上となる場合に正しい解を求めることができない、なぜなら、13の階乗は6,2」
https://oshiete.goo.ne.jp/qa/9824288.html