哈密尔顿回路问题Word文档格式.docx
- 文档编号:18701603
- 上传时间:2022-12-31
- 格式:DOCX
- 页数:14
- 大小:19.73KB
哈密尔顿回路问题Word文档格式.docx
《哈密尔顿回路问题Word文档格式.docx》由会员分享,可在线阅读,更多相关《哈密尔顿回路问题Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。
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!
)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 哈密尔顿 回路 问题