女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]題目:把n個(gè)骰子扔在地上,所有骰子朝上一面的點(diǎn)數(shù)之和為S。輸入n,打印出S的所有可能的值出現(xiàn)的概率。分析:骰子一共6個(gè)面,每個(gè)面上都有一個(gè)點(diǎn)數(shù),對(duì)應(yīng)的數(shù)字是1到 6之間的一個(gè)數(shù)字。所以,n個(gè)骰子的點(diǎn)數(shù)

題目:把n個(gè)骰子扔在地上,所有骰子朝上一面的點(diǎn)數(shù)之和為S。輸入n,打印出S的所有可能的值出現(xiàn)的概率。

分析:骰子一共6個(gè)面,每個(gè)面上都有一個(gè)點(diǎn)數(shù),對(duì)應(yīng)的數(shù)字是1到 6之間的一個(gè)數(shù)字。所以,n個(gè)骰子的點(diǎn)數(shù)和的最小值為n,最大值為6n。因此,一個(gè)直觀的思路就是定義一個(gè)長(zhǎng)度為6n-n的數(shù)組,和為S的點(diǎn)數(shù)出現(xiàn)的次數(shù)保存到數(shù)組第S-n個(gè)元素里。另外,我們還知道n個(gè)骰子的所有點(diǎn)數(shù)的排列數(shù)6^n。一旦我們統(tǒng)計(jì)出每一點(diǎn)數(shù)出現(xiàn)的次數(shù)之后,因此只要把每一點(diǎn)數(shù)出現(xiàn)的次數(shù)除以n^6,就得到了對(duì)應(yīng)的概率。

該思路的關(guān)鍵就是統(tǒng)計(jì)每一點(diǎn)數(shù)出現(xiàn)的次數(shù)。要求出n個(gè)骰子的點(diǎn)數(shù)和,我們可以先把n個(gè)骰子分為兩堆:第一堆只有一個(gè),另一個(gè)有n-1個(gè)。單獨(dú)的那一個(gè)有可能出現(xiàn)從1到6的點(diǎn)數(shù)。我們需要計(jì)算從1到6的每一種點(diǎn)數(shù)和剩下的n-1個(gè)骰子來計(jì)算點(diǎn)數(shù)和。接下來把剩下的n-1個(gè)骰子還是分成兩堆,第一堆只有一個(gè),第二堆有n-2個(gè)。我們把上一輪那個(gè)單獨(dú)骰子的點(diǎn)數(shù)和這一輪單獨(dú)骰子的點(diǎn)數(shù)相加,再和剩下的n-2個(gè)骰子來計(jì)算點(diǎn)數(shù)和。分析到這里,我們不難發(fā)現(xiàn),這是一種遞歸的思路。遞歸結(jié)束的條件就是最后只剩下一個(gè)骰子了。

基于這種思路,我們可以寫出如下代碼:

int?g_maxValue=6;

void?SubProbabilityofDices(int?original,?int?current,?int?value,?int?tempSum,?int?*pProbalities)
{
	if(current==1)
	{
		int?sum=value+tempSum;
		pProbalities[sum-original]++;
	}
	else
	{
		for(int?i=1;?i<=g_maxValue;?i++)
		{
			int?sum=value+tempSum;
			SubProbabilityofDices(original,?current-1,?i,?sum,?pProbalities);
		}
	}
}

void?SumProbabilityofDices(int?number,?int*?pProbabilities)
{
	for(int?i=1;?i<=g_maxValue;?i++)//第一個(gè)骰子
		SubProbabilityofDices(number,?number,?i,?0,?pProbabilities);

}

void?PrintSumProbabilityofDices_1(int?number)
{
	if(number<1)
		return;

	int?maxSum=number*g_maxValue;
	int*?pProbabilities=new?int?[maxSum-number+1];
	for(int?i=number;?i<=maxSum;?i++)
		pProbabilities[i-number]=0;

	SumProbabilityofDices(number,?pProbabilities);

	int?total=pow((double)g_maxValue,?number);
	for(i=number;?i<=maxSum;?i++)
	{
		float?ratio=(float)pProbabilities[i-number]/total;
		cout<<i<<":"<<ratio<<endl;
	}
	delete[]?pProbabilities;
}


上述算法當(dāng)number比較小的時(shí)候表現(xiàn)很優(yōu)異。但由于該算法基于遞歸,它有很多計(jì)算是重復(fù)的,從而導(dǎo)致當(dāng)number變大時(shí)性能讓人不能接受。

為了避免遞歸時(shí)的重復(fù)計(jì)算,我們很自然聯(lián)想到動(dòng)態(tài)規(guī)劃(DP)。用表格法,一行代表一個(gè)骰子,列表示各個(gè)S值,所以一共有6*N列。本來是要用N行的,可是這里只用了一個(gè)二維的數(shù)組,因?yàn)楝F(xiàn)在計(jì)算的值只與前一次計(jì)算的值相關(guān),所以其中一行保存上一次計(jì)算的結(jié)果,另一行保存正在計(jì)算的結(jié)果,這樣可以節(jié)省大量的空間。我們可以考慮用兩個(gè)數(shù)組來存儲(chǔ)骰子點(diǎn)數(shù)每一總數(shù)出現(xiàn)的次數(shù)。在一次循環(huán)中,第一個(gè)數(shù)組中的第n個(gè)數(shù)字表示骰子和為n出現(xiàn)的次數(shù)。那么在下一循環(huán)中,我們加上一個(gè)新的骰子。那么此時(shí)和為n的骰子出現(xiàn)的次數(shù),應(yīng)該等于上一次循環(huán)中骰子點(diǎn)數(shù)和為n-1、n-2、n-3、n-4、n-5與n-6的總和。所以我們把另一個(gè)數(shù)組的第n個(gè)數(shù)字設(shè)為前一個(gè)數(shù)組對(duì)應(yīng)的第n-1、n-2、n-3、n-4、n-5與n-6之和。

void?PrintSumProbabilityofDices_2(int?number)
{
	double*?pProbabilities[2];
	pProbabilities[0]=new?double[number*g_maxValue+1];
	pProbabilities[1]=new?double[number*g_maxValue+1];

	for(int?i=0;?i<number*g_maxValue+1;?i++)
	{
		pProbabilities[0][i]=0;
		pProbabilities[1][i]=0;
	}

	int?flag=0;
	for(i=1;?i<=g_maxValue;?i++)
		pProbabilities[flag][i]=1;

	for(int?k=2;?k<=number;?k++)
	{
		for(int?i=k;?i<=g_maxValue*k;?i++)
		{
			pProbabilities[1-flag][i]=0;
			for(int?j=1;?j<=i?&&?j<=g_maxValue;?j++)
				pProbabilities[1-flag][i]+=pProbabilities[flag][i-j];
		}
		flag=1-flag;
	}

	double?total=pow((double)g_maxValue,?number);

	for(i=number;?i<=g_maxValue*number;?i++)
	{
		double?ratio=pProbabilities[flag][i]/total;
		cout<<i<<":"<<ratio<<endl;
	}

	delete[]?pProbabilities[0];
	delete[]?pProbabilities[1];
}


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

納祥科技推出太陽能+Type-C雙充電自行車前燈方案,方案核心模塊包含太陽能板、單片機(jī)、三極管、3顆LED燈珠與1200mAh電池,通過低功耗單片機(jī)與三極管驅(qū)動(dòng),支持強(qiáng)光/弱光/爆閃3種模式,高流明遠(yuǎn)射程,適配多種車型

關(guān)鍵字: 方案開發(fā) 電子方案 自行車前燈方案 納祥科技

慕尼黑2025年9月11日 /美通社/ -- 當(dāng)?shù)貢r(shí)間9月9日,賽力斯動(dòng)力在德國(guó)慕尼黑國(guó)際車展期間舉辦技術(shù)發(fā)布與交流會(huì),正式在海外市場(chǎng)推出全新一代賽力斯超級(jí)增程、高效發(fā)動(dòng)機(jī)和新一代分布式電驅(qū)動(dòng)系統(tǒng),同時(shí)與來自全球的汽車產(chǎn)...

關(guān)鍵字: 慕尼黑 分布式 發(fā)動(dòng)機(jī) 新能源汽車

慕尼黑2025年9月11日 /美通社/ -- 高端智能電動(dòng)汽車品牌問界(AITO)在2025年德國(guó)國(guó)際汽車及智慧出行博覽會(huì)(IAA MOBILITY)上,正式發(fā)布了其最新全球產(chǎn)品陣容——專為中東市場(chǎng)深度本地化打造的AIT...

關(guān)鍵字: AI 智能駕駛 測(cè)試 生態(tài)系統(tǒng)

舍弗勒首次為中國(guó)頭部車企大規(guī)模生產(chǎn)高壓逆變磚 天津工廠一年內(nèi)完成量產(chǎn)準(zhǔn)備,逆變器模塊性能參數(shù)顯著提升 與合作伙伴羅姆半導(dǎo)體共研尖端碳化硅技術(shù),效率更高、性能更優(yōu) 模塊化可擴(kuò)展設(shè)計(jì)使逆變磚易于集成,可廣泛...

關(guān)鍵字: 逆變 高壓 逆變器 集成

舍弗勒以"專注驅(qū)動(dòng)技術(shù)的科技公司"為主題亮相IAA MOBILITY 2025(B3館B40展臺(tái)) 合并緯湃科技后首次亮相IAA MOBILITY,展示拓展后的汽車產(chǎn)品組合 憑借在軟件、...

關(guān)鍵字: 電氣 軟件 驅(qū)動(dòng)技術(shù) BSP

拉斯維加斯2025年9月11日 /美通社/ -- 在9月8日至11日舉辦的RE+ 2025展會(huì)上,全球綜合儲(chǔ)能解決方案供應(yīng)商德賽電池(Desay Battery)全面展示了其創(chuàng)新成果,并宣布與深圳市華寶新能源股份有限公司...

關(guān)鍵字: 電池 電芯 人工智能 鋰電

香港2025年 9月12日 /美通社/ -- 全球領(lǐng)先的互聯(lián)網(wǎng)社區(qū)創(chuàng)建者 - 網(wǎng)龍網(wǎng)絡(luò)控股有限公司 ("網(wǎng)龍"或"本公司",香港交易所股票代碼:777)欣然宣布,其子公司My...

關(guān)鍵字: AI 遠(yuǎn)程控制 控制技術(shù) BSP

慕尼黑2025年9月12日 /美通社/ -- 慕尼黑當(dāng)?shù)貢r(shí)間9月10日,在2025德國(guó)國(guó)際汽車及智慧出行博覽會(huì)(IAA MOBILITY)上,國(guó)際獨(dú)立第三方檢測(cè)、檢驗(yàn)和認(rèn)證機(jī)...

關(guān)鍵字: 測(cè)試 慕尼黑 模型 HUBER

上海2025年9月12日 /美通社/ -- 近日,國(guó)際獨(dú)立第三方檢測(cè)、檢驗(yàn)和認(rèn)證機(jī)構(gòu)德國(guó)萊茵TÜV大中華區(qū)(簡(jiǎn)稱"TÜV萊茵")為上海...

關(guān)鍵字: 測(cè)試 信息安全 安全管理 開關(guān)

廣州2025年9月12日 /美通社/ -- 9月11日,由國(guó)際獨(dú)立第三方檢測(cè)、檢驗(yàn)和認(rèn)證機(jī)構(gòu)德國(guó)萊茵TÜV大中華區(qū)(簡(jiǎn)稱"TÜV萊茵"...

關(guān)鍵字: 數(shù)字化 供應(yīng)鏈 控制 電子
關(guān)閉