質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

3回答

3036閲覧

モンテカルロ法で確率を求める

yukkuri_55

総合スコア240

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2016/12/14 07:37

編集2016/12/15 01:19

今、問題が5問あって、すべて3択問題とします。
全部回答したとして、1問も合わないいわゆるゼロ点になる確率は
何%でしょうか?

私は、0.66 * 0.66 * 0.66 * 0.66 * 0.66 * = 0.125...
0.125 * 100 = 12%と導き出しました

これであっているでしょうか?

ご指摘がありましたので、質問を訂正します。

###前提・実現したいこと
テストで5問あって、全部3択問題です。
このテストで0点をとる確率を求めたいです。

###発生している問題・エラーメッセージ

なし

###該当のソースコード

C/C++

1// モンテカルロ法.cpp : コンソール アプリケーションのエントリ ポイントを定義します。 2// 3 4#include "stdafx.h" 5 6// ダイレクトに求める 7void sub2() 8{ 9 double total = 0.666667 * 0.666667 * 0.666667 * 0.666667 * 0.666667; 10 printf( "sub2:total %f\n", total ); 11} 12 13int _tmain(int argc, _TCHAR* argv[]) 14{ 15 // for を使って求める 16 int i; 17 double total = 0.666667; 18 for( i=1; i<=5; i++ ) 19 { 20 printf( "i:%d total:%f\n", i, total ); 21 total = 0.666667 * total; 22 } 23 24 sub2(); 25 26 return 0; 27} 28

###試したこと
上記のソースコードを実行し、結果を得た
0.131688 とでたのでこれに100をかけて
13.1688% と出しました。

これでおおよそあっていますでしょうか?

###補足情報(言語/FW/ツール等のバージョンなど)
言語 C/C++
環境 Visual C++ 2010 Express

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

teratailはプログラムのことを聞く場所であって、数学の問題の答えを聞く場所ではありません。

ということで、プログラム的観点で答えを導きましょう。

モンテカルロ法

みなさん大好きモンテカルロ法です。これを使えば確率の知識に乏しくとも答え(厳密解とは言っていない)にたどり着けます。

① 3択を0,1,2の状態と考え、0~2の数字を乱数で取ってくる。

② ①で得た数が正解(仮に0としましょう)ならseikaiFlagを1にする。

③ ①、②の施行を5回繰り返し、もしseikaiFlagが1になっていなければ1問も正解していないということで、huseikaiCountを1増やします。

④ ③の施行を1000万回繰り返します。

⑤ huseikaiCountの数を1000万で割った後に100を掛けます。それが答え(厳密解とは言っていない)です。

投稿2016/12/14 10:44

hitsujimeeee

総合スコア486

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukkuri_55

2016/12/15 01:12

モンテカルロ法、参考になりました。ありがとうございました。
guest

0

問題の難易度にもよるのではないでしょうか?
この場合、3択はランダム選択なのでしょうか。

投稿2016/12/14 07:41

mugicya

総合スコア1046

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

(2/3)(2/3)(2/3)(2/3)(2/3)≒0.1317
と、正確に計算しないと。

投稿2016/12/14 07:59

PineMatsu

総合スコア3579

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukkuri_55

2016/12/15 01:13

はい、正確に計算すると私が出した答えとズレが生じています。 もっと正確に計算します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問