n人の点数を読み込みそれらの平均、分散を計算するプログラムを作りたいのですが分散の式がよく分かりません。
分散を求める式は第i番目の点数をxi、平均をμとすると
分散=1/nΣxi^2-μ^2
で、プラグラムを作ってみると
#include<stdio.h>
int main (void)
{
int i;
int sum=0;
int num,tmp;
printf("何人ですか");
scanf("%d",&num);
for(i=0; i<num; i++)
{
print("No. %d ", i+1)
scanf("%d",&tmp);
sum += tmp;
}
printf("平均:%.3f\n",(double)sum/num);
printf("分散:%.3f\n",(double){(sum-sum/num)*(sum+sum/num)}/num);
return(0);
}
というプログラムを作ってみたのですが分散の計算がうまくいきません。どなたか分散の計算のプログラムを教えて下さい。
C言語初めてまもないので不備があったらすみません。
No.2ベストアンサー
- 回答日時:
こんばんわ。
ぱっとみでおかしいなと思った部分は、
Σxi^2の部分だと思います。
Σxi^2っていうのは、
Σxi^2=Σx1^2+Σx2^2+・・・+Σxnum^2
っていうことです。
dogtaisiさんはΣxi^2をsum^2と計算しているので
分散の計算がおかしくなっているんじゃないでしょうか?
for文の中に、Σxi^2を計算する式を改めて作ってみるのはどうでしょう?
for(i=0; i<num; i++)
{
print("No. %d ", i+1)
scanf("%d",&tmp);
sum += tmp;
sigmax2 += tmp*tmp;
}
みたいな感じで。
自分自身も初心者なんで、的外れならごめんなさいね。
No.3
- 回答日時:
#1 の方へ
式を変形すると
http://aoki2.si.gunma-u.ac.jp/lecture/Univariate …
(1/nΣxi^2) - μ^2
になります(質問者さんにもわかりやすいように括弧をつけます)。
オーバーフローしやすいのであまり使いませんけど。
で、質問者さんのプログラムのおかしい点は#2さんの指摘の通りです。
各要素の2乗の和の平均を求めた上で、そこから平均値の2乗を引きます。
No.1
- 回答日時:
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
構文エラー";"が型の前にあり...
-
#if 1 #elseの意味について
-
C言語プログラムが理解できなくて…
-
c言語プログラミングで1から100...
-
初心者です。for文、if文を使っ...
-
C言語でfor文を用いたプログラ...
-
for文の中にswitch文はいれられ...
-
C言語 入力した数値の平均値の...
-
C言語の問題でわからないとこ...
-
c言語で平均をだす
-
C言語。どうしてコンパイルでき...
-
配列を使って魔方陣
-
配列を関数に渡す方法
-
C言語です
-
C言語でのトランプシャッフルに...
-
10進数を2進数に変換したい...
-
C言語の問題-配列について
-
xのy乗を求める問題で…(ただし...
-
C言語での引数の省略方法
-
信頼区間の1.96や1.65ってどこ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
構文エラー";"が型の前にあり...
-
プログラム
-
#if 1 #elseの意味について
-
for文の中にswitch文はいれられ...
-
配列を使って魔方陣
-
getcの改行判定
-
配列を関数に渡す方法
-
プログラミングで二番目に大き...
-
C言語階乗の総和を求める
-
scanf関数を用いての加減乗除%...
-
C言語で電卓を作成する。
-
C言語 プログラム
-
C言語の二分法のプログラムにつ...
-
C言語のwhile文を使った素数判...
-
while文について、c言語...
-
10進数からN進数に変換するプロ...
-
C言語です
-
C言語・アルゴリズムの勉強法(...
-
C言語のプログラミング (基礎...
-
全角文字の判定
おすすめ情報