题目大意:看完之后,觉得不肯能让我暴力,比较好想的就是初始化——每个点都求个最短路spfa,sum数组记录每个点到各个点的最短路之和,ans作为总和,之后一一删除边u-v,求关于u的最短路,如果dis[v]是无穷大——》输出INF,否则连通——》求出sum【u】——用一个新的变量num1记录不可覆盖,求出sumv==num2,输出+》ans - sum[u] - sum[v] + num1 + num2

也是回顾了一下链式前向星和spfa——queue最短路的求法

1·初始化开始点,入队

2.出队一个点(维护vis数组),扫描所有的以这个点为起点的边,连边

3.判断目标点是否在队伍中,不在队伍中入队

一直维护队列,vis数组,dis数组

/*
sum数组来存储以i为起点的最短路之和
ans表示i从1到n的所有sum[i]的和
摧毁道路u v后
1.uv是否还连通
2.求sum[u]
3.sum[v]
ans = ans - sum[u] - sum[v] + num1 + num2
*/ #include <iostream>
#include <stdio.h>
#include <string.h>
#include <queue>
#define inf 99999999
using namespace std;
const int maxn = 110;
const int maxm = 3030;
typedef long long ll; struct node{
int from,to,pre;
int cost;//之所以赋值cost是为了后面赋值为inf模拟删边
}e[maxm * 2]; int n,m,ans;//总和更新维护变量
int sum[maxn];//一个点到各个点的最短路和
int dis[maxn];//spfa求最短路——点i到开始点的当前最短路
int vis[maxn];//spfa求最短路——判断点i是否在队列中
int id[maxm],cnt;//链式前向星
int u[maxm],v[maxm];//存储数据
queue<int> q;
void init()
{
//一次输入仅仅初始化一次
memset(sum,0,sizeof(sum));
memset(id,-1,sizeof(id));
cnt = 0;
ans = 0;
} void add(int u,int v)
{
e[cnt].from = u;
e[cnt].to = v;
e[cnt].cost = 1;
e[cnt].pre = id[u];
id[u] = cnt++;
} int spfa(int s)
{
for(int i = 0;i <= n;i++)
{
dis[i] = inf;
}
memset(vis,0,sizeof(vis));
while(q.size())q.pop(); q.push(s);
dis[s] = 0;
vis[s] = 1;
while(q.size())
{
int now = q.front();
q.pop();
vis[now] = 0;
for(int i = id[now];~i;i = e[i].pre)
{
int to = e[i].to;
if(dis[to] > dis[now] + e[i].cost)
{
dis[to] = dis[now] + e[i].cost;
if(vis[to] == 0)
{
vis[to] = 1;
q.push(to);
}
}
}
}
int res = 0;
for(int i = 1;i <= n;i++)
res += dis[i];
return res;
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
init(); for(int i = 1;i <= m;i++)
{
scanf("%d%d",&u[i],&v[i]);
add(u[i],v[i]);
add(v[i],u[i]);
} for(int i = 1;i <= n;i++)
{
sum[i] = spfa(i);
ans += sum[i];
} for(int i = 1;i <= m;i++)
{
e[i*2-1].cost = inf;
e[i*2-2].cost = inf;
int num1 = spfa(u[i]);
if(dis[v[i]] >= inf)
printf("INF\n");
else
{
int num2 = spfa(v[i]);
printf("%d\n",ans + num1 + num2 - sum[u[i]] - sum[v[i]]);
}
e[i*2-1].cost = 1;
e[i*2-2].cost = 1;
}
}
return 0;
}

SPFA_queue_链式前向星最短路 & HDU2433的更多相关文章

  1. UESTC30-最短路-Floyd最短路、spfa+链式前向星建图

    最短路 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) 在每年的校赛里,所有进入决赛的同 ...

  2. 最短路 spfa 算法 && 链式前向星存图

    推荐博客  https://i.cnblogs.com/EditPosts.aspx?opt=1 http://blog.csdn.net/mcdonnell_douglas/article/deta ...

  3. HDU 2544最短路 【dijkstra 链式前向星+优先队列优化】

    最开始学最短路的时候只会用map二维数组存图,那个时候还不知道这就是矩阵存图,也不懂得效率怎么样 经过几个月的历练再回头看最短路的题, 发现图可以用链式前向星来存, 链式前向星的效率是比较高的.对于查 ...

  4. UESTC 30.最短路-最短路(Floyd or Spfa(链式前向星存图))

    最短路 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) 在每年的校赛里,所有进入决赛的同 ...

  5. 【最短路】Dijkstra+ 链式前向星+ 堆优化(优先队列)

    Dijkstra+ 链式前向星+ 优先队列   Dijkstra算法 Dijkstra最短路算法,个人理解其本质就是一种广度优先搜索.先将所有点的最短距离Dis[ ]都刷新成∞(涂成黑色),然后从起点 ...

  6. 单元最短路径算法模板汇总(Dijkstra, BF,SPFA),附链式前向星模板

    一:dijkstra算法时间复杂度,用优先级队列优化的话,O((M+N)logN)求单源最短路径,要求所有边的权值非负.若图中出现权值为负的边,Dijkstra算法就会失效,求出的最短路径就可能是错的 ...

  7. 【模板】链式前向星+spfa

    洛谷传送门--分糖果 博客--链式前向星 团队中一道题,数据很大,只能用链式前向星存储,spfa求单源最短路. 可做模板. #include <cstdio> #include <q ...

  8. 链式前向星版DIjistra POJ 2387

    链式前向星 在做图论题的时候,偶然碰到了一个数据量很大的题目,用vector的邻接表直接超时,上网查了一下发现这道题数据很大,vector可定会超的,不会指针链表的我找到了链式前向星这个好东西,接下来 ...

  9. poj-1459-最大流dinic+链式前向星-isap+bfs+stack

    title: poj-1459-最大流dinic+链式前向星-isap+bfs+stack date: 2018-11-22 20:57:54 tags: acm 刷题 categories: ACM ...

随机推荐

  1. 案例情景--在一次Oracle 数据库导出时 EXP-00008;ORA-00904:EXP-00000: oracle不同版本导入导出规则

    案例情景--在一次Oracle 数据库导出时: C:\Documents and Settings\Administrator>exp lsxy/lsxy@lsxy_db file=E:\lsx ...

  2. N! (大数,优化)

    Problem Description 输出N的阶乘.(注意时间限制150ms&&注意不能打表后输出) 打表的定义:在本地主机预先计算出了每个值对应的答案,并把输入和输出的映射直接写入 ...

  3. Architecture.SOLID-Principles

    SOLID Principles Reference 1. Single Responsibility http://en.wikipedia.org/wiki/Single_responsibili ...

  4. 基因组表达分析:如何选择RNA-seq vs. 芯片

    基因组表达分析:如何选择RNA-seq vs. 芯片 发布日期:2017-03-29 10:00 DNA 芯片(上图左侧)由附着在表面的核酸探针组成.首先,从样品中提取 RNA 并转化为互补 DNA( ...

  5. Luogu2149 [SDOI2009]Elaxia的路线-最短路+拓扑排序

    Solution 另外$ m <=5e5$. 两条最短路的 最长公共路径 一定是若干条连续的边, 并且满足拓扑序. 于是我们分别 正向 和反向走第二条路径,若该条边同时是两条最短路径上的边, 则 ...

  6. 当前页面刷新和动态添加控件的jquery事件绑定on

    当前页面刷新(console): location.reload() 给动态添加的控件添加js事件(委托): <ul> <li>菜单一</li> <li> ...

  7. swift 总结

    结构体(struct)属于值类型, 当值类型的实例被声明为常量的时候,它的所有属性也就成了常量. 属于引用类型的类(class)则不一样.把一个引用类型的实例赋给一个常量后,仍然可以修改该实例的变量属 ...

  8. Servlet 3.0 规范(二)注解驱动和异步请求

    Servlet 3.0 规范(二)注解驱动和异步请求 在 Servlet 3.0 时支持注解启动,不再需要 web.xml 配制文件. 一.Servlet 3.0 组件 Servlet 容器的组件大致 ...

  9. GBDT原理

    样本编号 花萼长度(cm) 花萼宽度(cm) 花瓣长度(cm) 花瓣宽度 花的种类 1 5.1 3.5 1.4 0.2 山鸢尾 2 4.9 3.0 1.4 0.2 山鸢尾 3 7.0 3.2 4.7 ...

  10. nginx 动静分离 以及 负载均衡配置

    测试环境 系统版本:win7 Nginx版本:nginx-1.8.1 Tomcat版本:tomcat-6.0.14 1动静分离配置 Nginx.conf 中 server中 server { list ...