




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、題目:n后問題(用拉斯維加斯算法)程序清單:Randomnumber.h#include <iostream>#include "time.h"using namespace std;/隨機(jī)數(shù)類const unsigned long maxshort=65536L;const unsigned long multiplier=1194211693L;const unsigned long adder=12345L;class RandomNumberprivate:/當(dāng)前種子unsigned long randSeed;public:/構(gòu)造函數(shù),默認(rèn)值0表示由系
2、統(tǒng)自動產(chǎn)生種子RandomNumber(unsigned long s=0);/產(chǎn)生0:n-1之間的隨機(jī)整數(shù)unsigned short Random(unsigned long n);/產(chǎn)生0,1)之間的隨機(jī)實(shí)數(shù)double fRandom(void);/產(chǎn)生種子RandomNumber:RandomNumber(unsigned long s)if(s=0) randSeed=time(0); /用系統(tǒng)時(shí)間產(chǎn)生種子else randSeed=s; /由用戶提供種子/產(chǎn)生0:n-1之間的隨機(jī)整數(shù)unsigned short RandomNumber:Random(unsigned long
3、n)randSeed=multiplier*randSeed+adder;return (unsigned short) (randSeed>>16)%n);/產(chǎn)生0,1)之間的隨機(jī)實(shí)數(shù)double RandomNumber:fRandom(void)return Random(maxshort)/double(maxshort);Nqueen LasVegas.cpp#include<iostream>#include "math.h"#include "randomnumber.h"using namespace std;cl
4、ass Queenfriend void nQueen(int); private:bool Place(int k); /測試皇后k置于第xk列的合法性bool QueensLV(void); /隨機(jī)放置n個皇后拉斯維加斯算法int n, /皇后個數(shù) *x,y1000; /解向量;bool Queen:Place(int k) /Place(k)用于測試將皇后k置于第xk列的合法性for(int j=1;j<k;j+)if(abs(k-j)=abs(xj-xk)|(xj=xk)return false;return true;bool Queen:QueensLV(void) /Que
5、ensLV(void)實(shí)現(xiàn)在棋盤上隨機(jī)放置n個皇后拉斯維加斯算法RandomNumber rnd; /隨機(jī)數(shù)產(chǎn)生器int k=1; /下一個放置的皇后編號int count=1;while(k<=n)&&(count>0)count=0;for(int i=1;i<=n;i+)xk=i;if(Place(k)ycount+=i;if(count>0) xk+=yrnd.Random(count);/隨機(jī)位置return (count>0); /count>0表示放置成功void nQueen(int n) /解n后問題的拉斯維加斯算法Quee
6、n X; /初始化X.n=n;int * p=new intn+1;for(int i=0;i<=n;i+)pi=0;X.x=p;/反復(fù)調(diào)用隨機(jī)放置n個皇后拉斯維加斯算法,直至放置成功while(X.QueensLV()cout<<"結(jié)果是:"<<endl;for(int i=1;i<=n;i+)for(int j=1;j<=n;j+)if(j=pi)cout<<"Q"<<" "if(j!=pi)cout<<"*"<<" "cout<<endl;break;delete p;void main()int n;c
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年有機(jī)硅、有機(jī)硅橡膠合作協(xié)議書
- 消防安全協(xié)議書范本
- 公司收購合同范本
- 廣告贊助費(fèi)用合同
- 2025年ABS專用料合作協(xié)議書
- 二零二五年度魚塘使用權(quán)及產(chǎn)品銷售權(quán)轉(zhuǎn)讓合同
- 二零二五年度生豬養(yǎng)殖與農(nóng)產(chǎn)品市場銷售合作合同范本
- 二零二五年度裝修工程安全管理合同
- 2025年度美容院客戶維護(hù)及經(jīng)營資產(chǎn)全面轉(zhuǎn)讓協(xié)議
- 二零二五年度餐飲品牌授權(quán)使用合同
- 2024年貴州現(xiàn)代物流產(chǎn)業(yè)集團(tuán)有限公司招聘筆試參考題庫含答案解析
- 20222023八下語文提優(yōu)輔導(dǎo)02(教師+學(xué)生)
- 共和國史(自己整理-僅供參考)
- 視頻監(jiān)控維保項(xiàng)目投標(biāo)方案(技術(shù)標(biāo))
- 涉農(nóng)(農(nóng)、林、水)地方標(biāo)準(zhǔn)宣貫推廣實(shí)施方案(試行)
- NB-T 11076-2023 高壓交流故障電流限制器通用技術(shù)規(guī)范
- 整縣(市、區(qū))屋頂分布式光伏開發(fā)方案書-V5
- 透水磚鋪裝施工方案
- 《十步訊問法》讀書筆記
- GB/T 42599-2023風(fēng)能發(fā)電系統(tǒng)電氣仿真模型驗(yàn)證
- 質(zhì)量問題解決方法之7鉆流程法
評論
0/150
提交評論