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 );
}
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
log_2(13!)≒32.54なので、 intが33bit以上ある処理系を使えば解決。
intが64bitなら、20!まで正しく求められます。
C言語の規格では、 intのビット幅は決まっていません。
あなたが使っているものが、たまたま int=32bitなだけです。
これって、 関数fn が、 階乗を求める関数ですよね?
ということは、int型を返す 関数fn では、どんなに中で正しく計算できても、 fn()は 32bitまでしか正しく返すことはできません。
つまり、intをやめない限り、 fn(13) は正しく求められません。
どこにも m ,n が出てきていませんが、もしかして順列 (nPm) または組合せ(nCm) を求めるために、階乗を使っているのでしょうか?
それなら、階乗を使った公式ではなく、別の計算方法を使います。
nPm なら n・(n-1)・…・'(n-m+1) を計算する。
nCm なら、 分子と分母に分けて、オーバーフローしないように掛けて、約分して既約分数にしてを繰り返す。
それでも、組合せの性質上、nは大して大きくできませんが。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語階乗の総和を求める 2 2023/03/04 23:31
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- Java javaでのプログラム(配列)について質問です. 2 2022/10/14 22:27
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
へんな現象
-
C言語 配列と関数の練習問題
-
C言語 エラーの原因がわからな...
-
c言語
-
std::set<int> で、ある値が何...
-
卒業研究でよく分からないとこ...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語プログラムについて質問です
-
C言語:アウトプット引数のキャ...
-
整数データの配列から同じ値の...
-
配列v2を逆順にしてv1に格納す...
-
C言語での引数の省略方法
-
あるプログラムの結果がうまく...
-
【至急】プログラムにエラーが...
-
C言語での奇数の和
-
足して100になるような乱数のア...
-
int型の変数値をバイト列として...
-
windows-findstrの正規表現を使...
-
systemの戻り値を取得する方法
-
乗換案内のC言語プログラムに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 配列と関数の練習問題
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
c言語
-
足して100になるような乱数のア...
-
C言語初心者です、、、お助けく...
-
数字列を3桁ごとにカンマで区切...
-
C言語 エラーの原因がわからな...
-
実数の整数部,小数部の取得
-
課題でつまってます・・・
-
商と剰余を同時に求める(C言語)
-
C言語の配列をC++のvectorに高...
-
std::set<int> で、ある値が何...
おすすめ情報