指数関数のマクローリン展開のプログラムです。
x=1の場合はしっかりと値が収束するのですが、それ以外ではうまくいきません。
以下のように組んだのですが、どこがまちがっているのでしょうか?
1.n!を求める。
2.x^nを求める。
3.これらを割る。
4.exに足していくという手順でやっているつもりです。
よろしくおねがいします。
______________________
#include<stdio.h>
main()
{
double a,i,j,k,l,m,n,x,ex;
printf("x=");
scanf("%lf",&x);
n=1;
ex=1;
m=x;
for(i=1;i<100;i++){
m=x;
n=n*i;
for(k=1;k<i;k++){
m=m*m;
}
a=m/n;
if(a<0.000001){
return 0;
}else{
m=x;
ex=ex+a;
}
printf("%lf ",ex);
}
return()
}
No.2ベストアンサー
- 回答日時:
分子・分母を個別に計算しているので、それぞれオーバーフロー(doubleで表現できる値の範囲を越える)してますね。
途中の m とか n の値を表示させてみるとわかると思います。それ以外にもおかしな点はありますが。
もとのプログラムをあまり変えない範囲で書き直すと、
#include <stdio.h>
main()
{
double x,a,ex,i;
printf("x=");
scanf("%lf",&x);
a=1;
ex=1;
for(i=1;i<100;i++){
a=a*x/i;
if(a<0.000001) break;
ex=ex+a;
printf("%lf\n",ex);
}
return 0;
}
数値計算は奥深いので、もっといいやり方があるかもしれません。
検証してみました。
これほど簡単にできるものなのですね。
考え方として、分子分母別で計算した方が考えやすいかと思ってやっていました。
これを参考にまた作りなおしてみようと思います。
ありがとうございました。
No.1
- 回答日時:
ご提示のソースは
>return()
ここでコンパイルエラーが出るため、論評できかねます。
お手元にある、x=1以外の場合でうまく動かないというソースを、
そっくりそのまま貼り付けていただけますか?
すいませんでした
その部分は書き間違いです・・・
こちらでコンパイルは正常にできています
コピペができないのでアレなんですけども・・・
x=5の場合
6.00000000
18.5000000
122.666666
16398.70833・・・
1271582153.・・・・・・
これ以降はものすごく大きな数字になります。
そして Inf Inf Inf・・・ と表示されています。
おそらくxのn乗のあたりがおかしいからこうなるのかと思っているのですが、朝からずっといろいろやってみていてこのありさまです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分 1 2022/07/19 17:03
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 malloc関数を使ってください!お願いします! 最 1 2022/07/21 09:28
- C言語・C++・C# c言語でユーザ関数を利用して複素数のべき乗と絶対値の数列を計算するプログラムが作りたいです。 3 2023/01/29 22:13
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# Cのdoubleの浮動小数点表示について 3 2023/04/17 13:14
- C言語・C++・C# C言語(構造体) 3 2022/07/05 20:08
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# C言語のマクローリン展開ローラン展開のコードについて 3 2022/12/15 14:45
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
int とdoubleの比較
-
3次方程式の求解プログラム(...
-
C言語の型による処理速度の違い
-
C言語初心者 構造体 課題について
-
プログラミングについて
-
sin(x)の近似について
-
c言語で、繰り返し文の中で、0....
-
C言語を実行すると-infが出てき...
-
指数関数のプログラムを組んで...
-
DLLの作り方
-
MATLABで画像のヒストグラムを...
-
Windowsでは出るエラーでMacで...
-
C言語 入力した数値の平均値の...
-
2次方程式の解を求めるプログ...
-
C言語で台形公式を使った二重積...
-
listに構造体を格納
-
64bit系でのmalloc
-
至急です! マクロ定義で #defi...
-
C 開放してるのにエラー(doubl...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C言語を実行すると-infが出てき...
-
c言語で、繰り返し文の中で、0....
-
C 開放してるのにエラー(doubl...
-
doubleの変数にintとintの割り...
-
至急です! マクロ定義で #defi...
-
C言語 関数プロトタイプ宣言の...
-
C言語の型による処理速度の違い
-
float型とdouble型の変数の違い...
-
int とdoubleの比較
-
関数におけるif文とreturn文に...
-
Cで3乗根を求める方法
-
2次方程式の解を求めるプログ...
-
c言語のコンパイルエラー canno...
-
浮動小数点の定数
-
-1.#IND00と出てしまうのですが...
-
doubleは常に%lfとするべきなのか
-
C言語のpow関数の不具合
-
difftime()について
-
C++で外積
おすすめ情報