uva539 卡坦岛 简单回溯!

2014-11-24 01:21:26 · 作者: · 浏览: 3
开始想复杂了,用了好多数组判断节点的度、边是否已经走过,结果导致超时了,后来简化成如下版本,走过的标志不需要另辟vis数组,只要将map【i】【j】和map【j】【i】赋值0即可。
#include  
#include  
  
using namespace std;  
  
int n,m,Max,map[30][30];  
  
void dfs(int node,int path)     //node:当前节点,path:当前路径长度  
{  
    int i;  
    if (path>Max) Max=path;  
    for (i=0;i
>n>>m&&n) { memset(map,0,sizeof(map)); for (int i=0;i>a>>b; map[a][b]=map[b][a]=1; //因是无向图,所以矩阵应为对称阵 } Max=0; for (int i=0;i