哈密尔顿回路问题Word文档格式.docx

上传人:b****5 文档编号:18701603 上传时间:2022-12-31 格式:DOCX 页数:14 大小:19.73KB
下载 相关 举报
哈密尔顿回路问题Word文档格式.docx_第1页
第1页 / 共14页
哈密尔顿回路问题Word文档格式.docx_第2页
第2页 / 共14页
哈密尔顿回路问题Word文档格式.docx_第3页
第3页 / 共14页
哈密尔顿回路问题Word文档格式.docx_第4页
第4页 / 共14页
哈密尔顿回路问题Word文档格式.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

哈密尔顿回路问题Word文档格式.docx

《哈密尔顿回路问题Word文档格式.docx》由会员分享,可在线阅读,更多相关《哈密尔顿回路问题Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。

哈密尔顿回路问题Word文档格式.docx

W[0].x=W[i+1].x;

W[0].y=W[i+1].y;

W[0].value=W[i+1].value;

returnW[0];

voidShortPath()//寻找最短路径

inti,j,s=0;

P[s]=0;

//起始点设为V0

Weightw_next;

//存放路径上的下一结点for(i=1;

i++)//有n个节点循环n次即可

w_next=min_value(s);

//根据当前节点找出路径上的下一节点T[w_next.x]++;

//标识加入路径中的节点

T[w_next.y]++;

sum_value+=w_next.value;

P[i]=w_next.y;

//记录加入路径的节点

s=w_next.y;

//推移当前节点

P[i]=0;

//回到起始点

sum_value+=G[s][0];

printf("

无向图为:

\n"

);

for(j=0;

j<

j++)printf("

%d"

G[i][j]);

\n用贪心算法求得的哈密顿回路为:

"

6;

printf("

V%d"

P[i]);

if(i!

=5)

->

\n\n哈密顿回路的总路径长度为:

%d\n"

sum_value);

调试成功,如下图所示:

D:

2x枝装文坤\M£

Dev93\MyProjeddgfsd\Debug\sdf,eJ<

eH

无向图为:

02819

205109

85053

t18585

»

9350

用贪心算法求得的哈密顿回路为:

V0->

U3->

U4->

V2->

U1->

U0

哈密顿回路的总路径长輿为’16

Presske^tocontinue

时间复杂度为0(n2)

二、贪心+分支限界

分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。

在分支限界法中,每一个活结点只有一次机会成为扩展结点。

活结点一旦成为扩展结点,就一次性产生其所有儿子结点。

在这些儿子结点中,导致不可行解或导致非最优解的儿子结点被舍弃,其余儿子结点被加入活结点表中。

此后,从活结点表中取下一结点成为当前扩展结点,并重复上述结点扩展过程。

这个过程一直持续到找到所需的解或活结点表为空时为止。

#include"

stdlib.h"

#definen5//结点个数为5

#defineNoEdge99999/结点之间没有路径的标志

typedefintType;

intG[n+1][n+1];

//图的权值矩阵

intS[n+1][n+1];

//每个顶点的连接边按序排列放入此矩阵

intVV[n+1];

//存放在哈密尔顿回路上的顶点

voidsort_adj(inti)//将各个顶点邻接的边按大小顺序存入{

intj,p,m,k;

Typetemp;

for(j=1;

=n;

j++)

S[i][j]=j;

p=1;

l1:

for(j=p,k=j+1;

G[i][S[i][j]]<

=G[i][k];

j=k,k++);

p=k;

temp=G[i][k];

m=k;

while((temp<

G[i][S[i][j]])&

(j>

0))

S[i][j+1]=S[i][j];

j--;

S[i][j+1]=m;

if(p<

n)

gotol1;

voidsort_v()//对各顶点调用sort_adj()方法

inti;

for(i=1;

sort_adj(i);

TypeBTSP(intvv[]){

Typec;

intU[n+1];

intV[n+1];

TypeCmin;

inti,j,l;

sort_v();

U[i]=0;

U[1]=1;

c=0;

Cmin=NoEdge;

l=1;

V[1]=1;

L0:

l++;

j=0;

L1:

if(j>

gotoL2;

if(U[S[V[l-1]][j]])

gotoL1;

U[S[V[l-1]][j]]=1;

if(c+G[V[l-1]][S[V[l-1]][j]]>

Cmin)

c+=G[V[l-1]][S[V[l-1]][j]];

V[l]=S[V[l-1]][j];

if(l<

gotoL0;

if(c+G[S[V[l-1]][j]][1]<

VV[i]=V[i];

Cmin=c+G[S[V[l-1]][j]][1];

L2:

l--;

if(l>

=2)

j=V[l];

U[j]=0;

c-=G[V[l-1]][j];

elseif(Cmin!

=NoEdge)returnCmin;

elsereturnNoEdge;

voidmain()

G[1][1]=NoEdge;

G[1][2]=1;

G[1][3]=3;

G[1][4]=4;

G[1][5]=10;

G[2][1]=1;

G[2][2]=NoEdge;

G[2][3]=2;

G[2][4]=2;

G[2][5]=1;

G[3][1]=3;

G[3][2]=2;

G[3][3]=NoEdge;

G[3][4]=4;

G[3][5]=1;

G[4][1]=4;

G[4][2]=2;

G[4][3]=4;

G[4][4]=NoEdge;

G[4][5]=11;

G[5][1]=10;

G[5][2]=1;

G[5][3]=1;

G[5][4]=11;

G[5][5]=NoEdge;

if(BTSP(VV)!

=NoEdge){

最优值为:

BTSP(VV));

printf("

最优解为:

for(i=1;

i<

=n;

i++)printf("

%d-->

VV[i]);

1\n"

else

无回路"

调试成功:

■'

D:

exe^装丈舛SDev98\MyProject^X^dgfsd\Debug\sdf.exe"

灵优值为江「最」尢獰为:

丄一>

2—馬一>

3—〉4—XL

*ressan^Itey七ocontinue

时间复杂度为0(n2)。

三、回溯法

回溯法是一种按照深度优先的策略从根结点开始搜索解空间树的算法,该算法既带

有系统性又带有跳跃性,它在包含问题的所有解的解空间树中,按照深度优先的策略,从根节点出发搜索解空间树。

算法搜索至解空间树的任一节点时,总是先判定该节点是否肯定不包含问题的解,如果肯定不包含,贝U跳过对以该节点为跟的子树的系统搜索,逐层向其祖先节点回溯。

否则,进入该子树,继续按深度优先的策略进行探索。

这种以深度优先的方式系统地搜索问题的解的算法称为回溯法。

回溯法可以用来求出问题的全

部解,也可以在求出问题的一个解之后停止对问题的求解,即只求该问题是否有解。

它适用于解一些组合数较大的问题。

利用回溯法解哈密尔顿回路存在性的C++算法如下:

#include<

iostream>

usingnamespacestd;

boolroad[8][8]={{0,1,0,0,1,0,0,0}

{1,0,1,0,0,0,1,0}

{0,1,0,1,0,1,0,0}

{0,0,1,0,0,0,0,1}

{1,0,0,0,0,1,0,0}

{0,0,1,0,1,0,1,0}

{0,1,0,0,0,1,0,1}

{0,0,0,1,0,0,1,0}};

intx[8]={0};

voidHaMiTonian(int);

voidNextValue(int);

voiddisplay();

intmain()

x[0]=1;

HaMiTonian

(1);

return0;

voidHaMiTonian(intm)

if(m>

7)return;

L:

NextValue(m);

if(x[m]==0)

return;

if(m==7&

road[0][x[7]-1])display();

HaMiTonian(m+1);

gotoL;

voidNextValue(intk){

intj;

l:

x[k]=(x[k]+1)%9;

if(x[k]==0)

if(road[x[k-1]-1][x[k]-1]){

for(j=O;

k;

if(x[j]==x[k])gotol;

return;

elsegotol;

voiddisplay。

for(inti=0;

8;

cout<

<

x[i]vv"

"

;

cout«

endl;

调试成功,如下图:

JD:

\exe妄装交彳牛SDev9MyProjectdgfsd\Debug\5df.€xerf

2348765

2784365

5&

348?

2

5678432

ressanykevtocontinue

时间复杂度为0(n)

四、穷举法

#include<

stdio.h>

stdlib.h>

#includevstring.h>

#definemin(a,b)(a)<

(b)?

(a):

(b)

#defineV5

intLength[V]={0};

intD[V][V]={

{0,6,4,5,8},

{6,0,3,2,7},

{4,3,0,3,1},

{5,2,3,0,2},

{8,7,1,2,0}

structedge{

intfromV;

inttoV;

intdist;

voidset(intf,intt,intd){

fromV=f;

toV=t;

dist=d;

voidoperator=(constedge&

e){set(e.fromV,e.toV,e.dist);

staticintcomp(constvoid*e1,constvoid*e2){

if(((edge*)e1)->

dist<

((edge*)e2)->

dist)return-1;

elseif(((edge*)e1)->

dist==((edge*)e2)->

dist)return0;

elsereturn1;

constintlen=16;

intAsum=0;

edgePath[V];

edgeArrE[len];

voidprintArrE(){

for(intp=0;

p<

len;

++p){

[%d,%d]=%d,"

ArrE[p].fromV,ArrE[p].toV,ArrE[p].dist);

}printf("

voidprintPath(){

V;

++p){//printPath();

Path[p].fromV,Path[p].toV,Path[p].dist);

voidcheckResult(){

printPath();

for(inti=0;

++i){

for(intj=i+1;

++j){if(Path[i].fromV==Path[j].toV&

Path[i].toV==Path[j].fromV)return;

intsum[V]={0};

for(ints=0;

s<

++s){sum[Path[s].fromV]++;

sum[Path[s].toV]++;

if(sum[0]==2&

sum[1]==2&

sum[2]==2&

sum[3]==2&

sum[4]==2){printf("

Thebestpathis:

exit(0);

#definex1000

boolcheckDuplicate(intc){intF[V]={x,x,x,x,x};

intT[V]={x,x,x,x,x};

for(inti=0;

V-c;

++i){intj=0;

do{if(Path[i].fromV==F[j]||Path[i].toV==T[j]){returntrue;

}else{F[j]=Path[i].fromV;

T[j]=Path[i].toV;

break;

}++j;

}while(j<

=i);

returnfalse;

voidreplace(intc){//replace"

count"

elementsatPath'

stailprintPath();

if(checkDuplicate(c))return;

for(intk=V-c;

k<

++k)Path[k]=ArrE[k];

//restoretailinformationif(c==0){

checkResult();

return;

intstart=V-c;

for(inti=start+1;

++i){//iisthepositioninArrE

Path[start]=ArrE[i];

replace(c-1);

intmain(){

inttmp=V-1;

while(tmp){

Asum+=tmp;

--tmp;

}//Forasolution,from/tovertexsummaryshouldbeAsum

Asum=%d\n"

Asum);

intidx=0;

for(intr=0;

r<

++r){

for(intc=0;

c<

++c){

if(r==c)continue;

ArrE[idx++].set(r,c,D[r][c]);

qsort(ArrE,len,sizeof(edge),comp);

printArrE();

memcpy(Path,ArrE,sizeof(edge)*V);

replace(i);

Nocirclefound\n"

%41叽E3,13=2ai>

2]-3,E0.3J=S,[0.13=6,

C2,4J=1,L3,1J=2,11,23=3,[0.3J=5,11,43=7,

£

2,43=1,f3U]-2,Elr2J-3,[0,3J=5,11,41=7,

Hl*E3,13=2,11.23-3.E0.3]=5,[0,41=8.

I2,4J=1,L3,l1=2>

[1,2]=3,[3,01=5..[0r4J=8,

[2,41-1,£

3,11=2,11,23=3.E3,0J=5,I2,t1=3,

2.41=1,E3,ll=2ai>

2]-3.[3,01-5,C2^1I=3,

E2,4J=1,L3,lJ=2,tl,2]=3,[3,01=5,.12,31=3,

(2,41-1,E3,l1=2,11,23=3,E3,0J=S,12,31=3,

2.41=1,L3,1J=2,E1,21=3,E3>

0]-5,C3F2I=3r

[2,4J=1,E3,lJ=2,I1,2]=3,[3,01=5,10,21=4,

[2,41=1,氤i1=2,11,23=3,E3,0J=Sa0,21=4,

2.41=1,t3;

X3=2,[1,21=3,E3.0]-5>

口*01=4,

[2,4J=1,饰门1唸,El>

2J-3,[3,01=5,10,31=5,

2,41=1.E9,l1=2,11,23=3.E3,aJ=S,10,31=5,

2.41=1,E3.1]=2ai>

2>

3,13,0J=5.[3,91=5,

C2,4J=1,(3P1J=2,[l,2]=3,[3,0J=5ai,01=6,

2,41=1.E3,l1=2,11,23=3,[3,01=5,[0,11=6,

[2,41=1,13,11=2,[1,21=3#I3r0]«

5.[B,l]=6»

C2,4J=1,13,13=2,[1,21-3*[3,01=5,11,4>

7,

12,43=4,13,1J-2,El,21*3,E3,0J=S,11,41=7,

[2^43=1.J[3,1J=2,I:

1,2]=3#E3>

0]=5,[0,41=8,

[2*41-1*[3,1J=2,C1,2]=3,[3,0J=5,[0,41=8,

rhebestpathis:

[2,4J=1,[3,11=2,[1,21=3,[3,01=5,10,43=8,Pressan^keutocontinue

时间复杂度为(n!

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1