http://acm.hdu.edu.cn/showproblem.php?pid=1869
#include
#include
#define INF 0x3f3f3f3f
int map[110][110];
int dis[220];
bool used[220];
int n;
bool dijkstra(int u)
{
int i,j;
memset(used,0,sizeof(used));
memset(dis,INF,sizeof(dis));
int pos=u;
for(i=0;i7) break;//只要两个人通过其他人的依然没有连通就不可能六度分离成立
used[pos]=1;
dis[pos]=min;
for(j=0;jmap[pos][j]+dis[pos])
{
dis[j]=map[pos][j]+dis[pos];
}
}
}
if(i
//SPFA
#include
#include
#include
#define MAXN 110
#define MAXM 220
#define INF 0x3f3f3f3f
using namespace std;
struct Edge
{
int u, v, w;
int next;//下一个结构体变量的下标
}edge[MAXM];
int head[MAXM];//下标为起点u,值为对应结构体下标
int vis[MAXN];//判断是否加入队列了
int M, N;
int num;
int low[MAXN];//存最短路径
void Add_Edge(int u, int v, int w)//加边
{
Edge E={u, v, w, head[u]};//初始化结构体
edge[num]=E;//直接赋值
head[u]=num++;
}
bool SPFA(int s)
{
int i, j;
queue Q;
memset(low, INF, sizeof(low));
memset(vis, 0, sizeof(vis));
vis[s] = 1;
low[s]=0;
Q.push(s);
while(!Q.empty())
{
int u=Q.front();
Q.pop();
//vis[u]=0;//出队列了,不在队列就变成0
for(j = head[u]; j != -1; j = edge[j].next)
{
int v = edge[j].v;
if(low[v] > low[u] + edge[j].w)
{
low[v] = low[u] + edge[j].w;
if(!vis[v] )
{
vis[v]=1;
Q.push(v);
}
}
}
}
for(int i=0;i7||low[i]==INF) return 1;
}
return 0;
}
int main()
{
int u, v, w;
while(~scanf("%d%d", &N, &M))
{
memset(head, -1, sizeof(head));
num=0;
while(M--)
{
scanf("%d%d", &u, &v);
Add_Edge(u, v, 1);
Add_Edge(v, u, 1);//无向边
}
bool flag=1;
for(int i=0;i