導航:首頁 > 源碼編譯 > c語言演算法概率計算

c語言演算法概率計算

發布時間:2022-07-03 04:37:21

Ⅰ 用C語言編寫一個程序,求擲硬幣1000次,至少有一次連續出現10次正面的概率。或者講講演算法

有兩種辦法:
第一種就是用隨機數進行模擬,然後進行至少100輪的模擬,取平均數
第二種就是用公式,根據概率學進行公式推導,然後使用C語言進行計算。
第一種並不能很准確,但是有說服力,模擬輪數越多越趨向於准確
第二種准確並有說服力,但是需要理論支持去計算。
公式的話:
全部可能出現的排列,是2的1000次方
特定位置可能出現滿足的排列,比如前10個都是正面,剩下的隨便排列,就是2的990次方
特定位置數,一共是991個
所以,幾率就是:991 * 2^990 / 2^1000
(好久沒有算過了,可能不太對,但是思路差不多,你好好想想吧)
因為,前11個都是正面的,同時滿足第一個和第二個位置的,是重復,需要排除一個,所以還需要額外考慮排除,需要進行處理一下……實際比上述的幾率小,具體公式仍需推導……非專業人員幫不到你

Ⅱ c語言 求隨機數分布概率

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<stddef.h>

intmain(){
floata,sum;

inti,j,n,m;

//100次求0-1之間的隨機數之和在0-11-2之間的概率分布次數
for(i=0;i<100;i++){
srand(time(NULL));
for(j=0;j<10;j++){
a=(float)rand()/RAND_MAX;
sum+=a;
}
if(sum>=0&&sum<=1)
n++;
}
if(sum>1&&sum<=2){
m++;
}
}

printf("01=%d12=%d ",n,m);

return0;
}

Ⅲ 如何用C語言實現求概率期望

用一個數組存放這100個概率。然後隨機生成N個0~99的數。以隨機生成的數為下標讀取數組里的數。然後相乘。。

Ⅳ C語言 隨機數 概率

計算機里的取隨機數函數是均勻分布的隨機數。
0.0005的概率,相當於2000個數里取一個。
所以我們可以
在0到1999范圍里取隨機數,如果取到數值
1000,我們就得1(並響鈴),否則得0。
#include
<stdio.h>
#include
<stdlib.h>
#include
<math.h>
#include
<time.h>
void
main()
{
long
int
i,y;
double
x,
r,
M
=
2000.0;
srand((unsigned)time(NULL));
for
(i=0;i<5000;i++)
//
取5000個
{
r
=
(
(double)rand()
/
((double)(RAND_MAX)+(double)(1))
);
x
=
(r
*
M);
y
=
(long
int)
x;
if
(y
==
1000)
{
printf("1
");printf("\007");
//
如果得1,就響鈴!
}
else
printf("0
");
};
}

Ⅳ C語言中如何表示概率

現成的函數沒有,可以通過產生隨機數實現概率。
srand((unsigned)time(NULL));
int m,r=0;
m=rand()%10;
if(m==1||m==2||m==3||m==4||m==5||m==6||m==7)
{
r=r+1;
}
這段代碼中,執行r=r+1的概率就是0.7
希望可以幫到你

Ⅵ c語言概率法求圓周率

#include<stdio.h>
#include<stdlib.h>
intmain()
{doublex,y;
intm=0,n=10000000,i;
srand(time(0));
for(i=0;i<n;i++)
{x=(double)rand()/RAND_MAX;
y=(double)rand()/RAND_MAX;
if(x*x+y*y<1)m++;
}
printf("%lf ",4.0*m/n);
return0;
}

Ⅶ c語言求概率

這是典型的古典概型,直接用窮舉法計算即可。
計算思路是遍歷1到10共10個數的所有組合(用goNext函數),統計出組合總數count與7個數之和等於20的組數successNumber,這兩個數的商successNumber/count就是所求的概率。
計算結果為:
總次數: 10000000, 成功次數: 26544, 概率: 0.0026544
程序可以如下實現:
#include <stdio.h>
int data[7];

int goNext()
{
int i;
for ( i = 0; i < 7 && ++data[i] > 10; ++i ) data[i] = 1;
if ( i == 7 ) return 0;
return 1;
}

void main()
{
int i, m;
double p;
long count = 0, successNumber = 0;
for ( i = 0; i < 7; ++i) data[i] = 1;
do
{
++count;
for ( i = 0, m = 0; i < 7; ++i ) m += data[i];
if ( 20 == m ) ++ successNumber;
} while ( goNext() );
p = (double) successNumber / (double) count;
printf("總次數: %d, 成功次數: %d, 概率: %.7lf\n", count, successNumber, p);
}

Ⅷ n個人生日完全不同的概率的演算法 C語言

}
void guoling()interrupt 0 using 1
{
led=!led;
led1=0;
henwen=0;
TR0=1;
}
void toser()interrupt 1 using 1
{ TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
henwen=1;
led1=1;
led=0;
TR0=0;
}

Ⅸ 如何用c語言隨機生成一個概率

隨機生成一個數倒是可以,概率的話,直接用1除以生成的數就可以了

Ⅹ 【C語言】關於概率計算的方法

我想是因為for (i=1;b>=1;i++)這一句無效。

前面b=0,循環條件是b>=1,所以不循環的。

另外b=b+0.1*pow(0.9,i-1);這句的0.1後面應該加上f,否則類型不對。

這個是改動過的代碼

#include <stdio.h>

#include <math.h>

int main()

{

int i;

long double b;

b=0;

for (i=1;b<=1;i++)

{

b=b+0.1f*pow(0.9,i-1);

}

printf("%d ", i);

return 0;

}

時間有些晚了,答題有點倉促,不知道能不能行,如果出現問題,希望海涵。

閱讀全文

與c語言演算法概率計算相關的資料

熱點內容
蘋果用戶app如何退款 瀏覽:889
解壓方式就是喝酒 瀏覽:396
麥塊怎麼添加到游戲伺服器 瀏覽:962
噴油螺桿製冷壓縮機 瀏覽:581
python員工信息登記表 瀏覽:377
高中美術pdf 瀏覽:161
java實現排列 瀏覽:513
javavector的用法 瀏覽:982
osi實現加密的三層 瀏覽:233
大眾寶來原廠中控如何安裝app 瀏覽:916
linux內核根文件系統 瀏覽:243
3d的命令面板不見了 瀏覽:526
武漢理工大學伺服器ip地址 瀏覽:149
亞馬遜雲伺服器登錄 瀏覽:525
安卓手機如何進行文件處理 瀏覽:71
mysql執行系統命令 瀏覽:930
php支持curlhttps 瀏覽:143
新預演算法責任 瀏覽:444
伺服器如何處理5萬人同時在線 瀏覽:251
哈夫曼編碼數據壓縮 瀏覽:428