问题 C: 最短路径

在洛谷上刷最短路的题然后被老师拉回去做算法笔记上面的题。。。

拿到这道题,先确定所有路径唯一,然后是无向边,那么对于边权处理,直接赋值为2的k次方就可以了,然后直接跑最短路。

这种思路非常暴力,但仔细看题目的数据范围,k<=500,ull你估计都存不下,没救。有的同学可能会想,反正最后都要mod 1e5,那我在存储的时候mod就行了嘛,很多题都可以这样。但是对于最短路,你明显不可能这么跑,看下面这个例子

显然,你处理之后肯定会出错,那你就要换个思想了。如果你把边权2^k直接存储为k会怎么样呢?如果再进行一次最小生成树,最终处理的结果和跑最短路的答案其实是一样的(如图)

这样来想,这道题就迎刃而解了,在处理好最小生成树之后,我们知道出发点,然后DFS一遍整颗树,处理出每一个边权,记住有可能会有孤儿城市,与其他城市不连通,特判为-1

#include<bits/stdc++.h>
using namespace std;
const int MAXN=1e5+50;
const int mod=100000;
int f[MAXN];
int n,m;
int po[505];
struct edge {
int to,net,v;
} ee[MAXN]; //链式前向星
int head[MAXN];
int find(int x) {
if(f[x]==x) return x;
return f[x]=find(f[x]);
}
void merge(int x,int y) {
f[find(x)]=find(y);
}//并查集标准操作
int tot;
void add(int u,int v,int w) {
ee[++tot].net=head[u];
ee[tot].to=v;
ee[tot].v=w;
head[u]=tot;
}//建边
int ans[MAXN];
bool vis[MAXN];
void dfs(int s) {
vis[s]=1; //已经走过这个点
for(register int i=head[s]; i; i=ee[i].net)
if(!vis[ee[i].to]) { //如果没有走过
ans[ee[i].to]=(ans[s]%mod+po[ee[i].v])%mod; //当前节点的距离是父亲节点的距离+当前的权值
dfs(ee[i].to); //继续找儿子节点
}
}
int main() {
po[0]=1;
for(register int i=1;i<500;i++) po[i]=po[i-1]%mod*2%mod; //预处理2的幂
while(scanf("%d%d",&n,&m)!=EOF) {
memset(ans,0,sizeof ans);
memset(ee,0,sizeof ee);
memset(f,0,sizeof f);
memset(vis,false,sizeof vis);
memset(head,0,sizeof head);
tot=0; //多组数据一定记得清空数组和变量
for(register int i=0; i<n; i++) f[i]=i; //并查集初始化
for(register int i=1; i<=m; i++) { //最小生成树的实现
int u,v;
scanf("%d%d",&u,&v);
int x=find(u),y=find(v);
if(x!=y) { //如果不在一个集合
add(u,v,i-1);
add(v,u,i-1); //建双向变
merge(x,y); //合并
} //标准的Kruskal
}
dfs(0); //dfs找路的长度
for(register int i=1; i<n; i++) {
if(vis[i]!=0) {
cout<<ans[i]%mod<<endl;
} else cout<<-1<<endl; //处理答案,如果没被访问过,说明是孤儿
}
}
return 0;
}

问题 C: 最短路径的更多相关文章

  1. Johnson 全源最短路径算法

    解决单源最短路径问题(Single Source Shortest Paths Problem)的算法包括: Dijkstra 单源最短路径算法:时间复杂度为 O(E + VlogV),要求权值非负: ...

  2. Floyd-Warshall 全源最短路径算法

    Floyd-Warshall 算法采用动态规划方案来解决在一个有向图 G = (V, E) 上每对顶点间的最短路径问题,即全源最短路径问题(All-Pairs Shortest Paths Probl ...

  3. Dijkstra 单源最短路径算法

    Dijkstra 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法,由计算机科学家 Edsger Dijkstra 于 1956 年 ...

  4. Bellman-Ford 单源最短路径算法

    Bellman-Ford 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法.该算法由 Richard Bellman 和 Leste ...

  5. 最短路径算法-Dijkstra

    Dijkstra是解决单源最短路径的一般方法,属于一种贪婪算法. 所谓单源最短路径是指在一个赋权有向图中,从某一点出发,到另一点的最短路径. 以python代码为例,实现Dijkstra算法 1.数据 ...

  6. bzoj 4016: [FJOI2014]最短路径树问题

    bzoj4016 最短路路径问题 Time Limit: 5 Sec Memory Limit: 512 MB Description 给一个包含n个点,m条边的无向连通图.从顶点1出发,往其余所有点 ...

  7. 51nod 1459 迷宫游戏 (最短路径—Dijkstra算法)

    题目链接 中文题,迪杰斯特拉最短路径算法模板题. #include<stdio.h> #include<string.h> #define INF 0x3f3f3f3f ],v ...

  8. C++迪杰斯特拉算法求最短路径

    一:算法历史 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以 ...

  9. 求两点之间最短路径-Dijkstra算法

     Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.D ...

  10. 最短路径之Floyd算法

    Floyd算法又称弗洛伊德算法,也叫做Floyd's algorithm,Roy–Warshall algorithm,Roy–Floyd algorithm, WFI algorithm. Floy ...

随机推荐

  1. Java实现 蓝桥杯 算法提高 菱形

    试题 算法提高 菱形 请编程输出一个菱形.输入为菱形中心到顶点的距离 样例输入 2 样例输出 import java.util.Scanner; public class Main { public ...

  2. Java实现 LeetCode 454 四数相加 II

    454. 四数相加 II 给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j] + C[k] + D[l] = 0. 为 ...

  3. Java实现 LeetCode 447 回旋镖的数量

    447. 回旋镖的数量 给定平面上 n 对不同的点,"回旋镖" 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺 ...

  4. Java实现高效便捷还容易懂的排序算法

    PS:我现在越来越认为排序大法是,很深的算法了,就是简单的几个步骤,网上的大佬们能给你玩出花来(ง •_•)ง public class zimuzhenlie2 { public static vo ...

  5. Java实现 LeetCode 171 Excel表列序号

    171. Excel表列序号 给定一个Excel表格中的列名称,返回其相应的列序号. 例如, A -> 1 B -> 2 C -> 3 ... Z -> 26 AA -> ...

  6. Java实现 蓝桥杯VIP 算法提高 项链

    算法提高 项链 时间限制:1.0s 内存限制:512.0MB 问题描述 由 n(1≤n≤100) 个珠子组成的一个项链,珠子有红.蓝.白三种颜色,各种颜色的珠子的安排顺序由键盘输入的字符串任意给定.蓝 ...

  7. PAT A+B和C

    题目描述 给定区间[-2的31次方, 2的31次方]内的3个整数A.B和C,请判断A+B是否大于C. 输入描述: 输入第1行给出正整数T(<=10),是测试用例的个数.随后给出T组测试用例,每组 ...

  8. iOS-PCH File的快速导入方法和使用

    PCH的文件的用途:      在实际的项目开发中,如果很多地方都在使用某个类的头文件,很多地方都在使用同一个”宏”的时候:很多地方用到了NSLog()函数, 在app发布的时候,想清除掉时,此时就需 ...

  9. 关于echart的x轴固定为0-24小时显示一天内的数据

    需求: echart折线图横坐标x轴固定显示为0-1-2-3-...-23-24一共24小时的数据. 根据需求,我在网上以及echart官网,发现x轴无论type是类目轴还是时间,都是自动处理的,尤其 ...

  10. ecshop头部添加所在城市

    首先,在/includes/lib_main.php中,找到代码:function assign_template($ctype = '', $catlist = array())   ,在方法中添加 ...