先用DFS把必經點找出來,然後取其中到入口長度最大的那個
但是先用BFS求各點到入口的距離,從大到小排序,依次從大的開始檢驗是否為必經點,輸出找到的第一個,這樣卻WA了。。。
對這道題還是沒有完全理解清楚。。。
AC代碼:(在原錯誤碼基礎上修改的,有點繁雜)
#include<iostream><br />#include<queue><br />using namespace std;<br />struct node<br />{<br />int d;<br />int v;<br />}dis[101];<br />int g[101][101];<br />int u[101],r[101];<br />int n,goal;<br />int cmp(const node &a,const node &b)<br />{<br />return a.d<b.d;<br />}<br />int dfs(int s,int del)<br />{<br />int i,j;<br />if(s==goal)<br />return 1;<br />u[s]=1;<br />for(i=0;i<n;i++)<br />{<br />if(i==del)<br />continue;<br />if(g[s][i]&&!u[i])<br />{<br />if(dfs(i,del))<br />return 1;<br />}<br />}<br />return 0;<br />}<br />void bfs()<br />{<br />int i,j,k,l,ans;<br />queue<int>q;<br />q.push(0);<br />u[0]=1;<br />dis[0].d=0;<br />dis[0].v=0;<br />while(!q.empty())<br />{<br />i=q.front();<br />q.pop();<br />for(j=0;j<n+1;j++)<br />{<br />if(!u[j]&&g[i][j])<br />{<br />dis[j].d=dis[i].d+1;<br />dis[j].v=j;<br />u[j]=1;<br />q.push(j);<br />}<br />}<br />}<br />}<br />int main()<br />{<br />int i,j,k,cnt,a,b,flag,suc,ans;<br />cnt=0;<br />suc=0;<br />cin>>n>>goal;<br />while(scanf("%d %d",&a,&b)!=EOF&&(a||b))<br />{<br />g[a][b]=1;<br />}<br />bfs();<br />for(i=0;i<n;i++)<br />{<br />memset(u,0,sizeof(u));<br />u[dis[i].v]=1;<br />if(dis[i].v==goal)<br />continue;<br />if(!dfs(0,dis[i].v))<br />{<br />r[cnt++]=i;<br />}<br />}<br />ans=r[0];<br />for(i=0;i<cnt;i++)<br />{<br />if(dis[r[i]].d>dis[ans].d)<br />ans=dis[r[i]].v;<br />}<br />printf("Put guards in room %d./n",ans);<br />return 0;<br />}<br />