• 迪杰斯特拉算法--O(n^2)

    #include"iostream"
    #include"cstring"
    #include"cstdio"
    using namespace std;
    const int inf = 0x3f3f3f3f;
    typedef long long LL;
    int map[][];
    int ans[], n, m;
    bool flag[];
    void dij() {
    for(int i = ; i <= n; i++)
    ans[i] = map[][i];
    ans[] = ;
    memset(flag, true, sizeof(flag));
    flag[] = false;
    for(int i = ; i < n; i++) {
    int v, mn = inf;
    for(int j = ; j <= n; j++)
    // 此处建议用 <= 因为map和mx都是初始化为inf,如果用 < 可能一个都找不到导致v是随机值而产生RE。当然也可采用其他方式避免v的随机值;
    if(ans[j] <= mn && flag[j]) {
    mn = ans[j];
    v = j;
    }
    for(int j = ; j <= n; j++)
    if(ans[v] + map[v][j] < ans[j])
    ans[j] = ans[v] + map[v][j];
    flag[v] = false;
    }
    }
    int main() {
    int a, b, c;
    while(scanf("%d%d", &n, &m) && (n || m)) {
    memset(map, inf, sizeof(map));
    while(m--) {
    scanf("%d%d%d", &a, &b, &c);
    if(map[a][b] > c)
    map[a][b] = map[b][a] = c;
    }
    dij();
    printf("%d\n", ans[n]);
    }
    return ;
    }
  • 迪杰斯特拉算法堆优化--O(nlgn) 以链式前向星建图
    #include "bits/stdc++.h"
    using namespace std;
    typedef pair<int, int> PII;
    const int MAXN = ;
    const int INF = 0x3f3f3f3f;
    struct Edge {
    int t, w, n;
    } edge[MAXN << ];
    int tot, tail[MAXN], dis[MAXN];
    bool use[MAXN];
    void add(int u, int v, int w) {
    edge[tot].t = v;
    edge[tot].w = w;
    edge[tot].n = tail[u];
    tail[u] = tot++;
    }
    void dij() {
    memset(dis, INF, sizeof(dis));
    memset(use, false, sizeof(use));
    // PII的first表示权重,second表示节点。后面部分是为了让优先队列每次取最小值
    priority_queue<PII, vector<PII>, greater<PII> > que;
    for (int i = tail[]; i != -; i = edge[i].n) {
    int t = edge[i].t;
    int w = edge[i].w;
    if (w < dis[t]) {
    dis[t] = w;
    que.push({w, t});
    }
    }
    use[] = true;
    while (!que.empty()) {
    int v = que.top().second;
    que.pop();
    if (use[v]) continue;
    use[v] = true;
    for (int i = tail[v]; i != -; i = edge[i].n) {
    int t = edge[i].t;
    int w = edge[i].w;
    if (dis[v] + w < dis[t]) {
    dis[t] = dis[v] + w;
    que.push({dis[t], t});
    }
    }
    }
    }
    int main() {
    int n, m, u, v, w;
    while (scanf("%d%d", &n, &m) && (n || m)) {
    tot = ;
    memset(tail, -, sizeof(tail));
    while (m--) {
    scanf("%d%d%d", &u, &v, &w);
    add(u, v, w);
    add(v, u, w);
    }
    dij();
    printf("%d\n", dis[n]);
    }
    return ;
    }
  • 迪杰斯特拉算法堆优化--O(nlgn) 以vector建图
    #include "bits/stdc++.h"
    using namespace std;
    typedef pair<int, int> PII;
    const int MAXN = ;
    const int INF = 0x3f3f3f3f;
    vector<PII> vc[MAXN];
    int dis[MAXN];
    bool use[MAXN];
    void dij() {
    memset(dis, INF, sizeof(dis));
    memset(use, false, sizeof(use));
    priority_queue<PII, vector<PII>, greater<PII> > que;
    for (int i = ; i < vc[].size(); i++) {
    PII p = vc[][i];
    if (p.second < dis[p.first]) {
    dis[p.first] = p.second;
    que.push({dis[p.first], p.first});
    }
    }
    use[] = true;
    while (!que.empty()) {
    int v = que.top().second;
    que.pop();
    if (use[v]) continue;
    use[v] = true;
    for (int i = ; i < vc[v].size(); i++) {
    PII p = vc[v][i];
    if (dis[v] + p.second < dis[p.first]) {
    dis[p.first] = dis[v] + p.second;
    que.push({dis[p.first], p.first});
    }
    }
    }
    }
    int main() {
    int n, m, u, v, w;
    while (scanf("%d%d", &n, &m) && (n || m)) {
    for (int i = ; i <= n; i++) vc[i].clear();
    while (m--) {
    scanf("%d%d%d", &u, &v, &w);
    vc[u].push_back({v, w});
    vc[v].push_back({u, w});
    }
    dij();
    printf("%d\n", dis[n]);
    }
    return ;
    }
  • 弗洛伊德算法--O(n^3)
    #include"iostream"
    #include"cstring"
    #include"cstdio"
    using namespace std;
    const int inf = 0x3f3f3f3f;
    typedef long long LL;
    int map[][];
    int n, m;
    void Floyd() {
    for(int k = ; k <= n; k++)
    for(int i = ; i <= n; i++)
    for(int j = ; j <= n; j++)
    if(map[i][k] + map[k][j] < map[i][j])
    map[i][j] = map[i][k] + map[k][j];
    }
    int main() {
    int a, b, c;
    while(scanf("%d%d", &n, &m) && (n || m)) {
    memset(map, inf, sizeof(map));
    while(m--) {
    scanf("%d%d%d", &a, &b, &c);
    if(map[a][b] > c)
    map[a][b] = map[b][a] = c;
    }
    Floyd();
    printf("%d\n", map[][n]);
    }
    return ;
    }
  • SPFA算法--O(KE)--E是边数,K一般为2-3
    #include"iostream"
    #include"cstring"
    #include"cstdio"
    #include"queue"
    using namespace std;
    const int inf = 0x3f3f3f3f;
    typedef long long LL;
    int map[][];
    int ans[], n, m;
    bool flag[];
    void SPFA() {
    memset(ans, inf, sizeof(ans));
    memset(flag, true, sizeof(flag));
    ans[] = ;
    queue<int>q;
    q.push(); flag[] = false;
    while(!q.empty()) {
    int v = q.front();
    flag[v] = true;
    q.pop();
    for(int i = ; i <= n; i++)
    if(ans[v] + map[v][i] < ans[i]) {
    ans[i] = ans[v] + map[v][i];
    if(flag[i]) {
    q.push(i);
    flag[i] = false;
    }
    }
    }
    }
    int main() {
    int a, b, c;
    while(scanf("%d%d", &n, &m) && (n || m)) {
    memset(map, inf, sizeof(map));
    while(m--) {
    scanf("%d%d%d", &a, &b, &c);
    if(map[a][b] > c)
    map[a][b] = map[b][a] = c;
    }
    SPFA();
    printf("%d\n", ans[n]);
    }
    return ;
    }
  • 深度优先搜索算法
    #include"iostream"
    #include"cstring"
    #include"cstdio"
    #include"queue"
    using namespace std;
    const int inf = 0x3f3f3f3f;
    typedef long long LL;
    int map[][];
    int ans, n, m;
    bool flag[];
    void DFS(int i, int k) {
    if(i == n) {
    if(k < ans)
    ans = k;
    return;
    }
    for(int j = ; j <= n; j++)
    if(flag[j] && k + map[i][j] < ans) {
    flag[j] = false;
    DFS(j, k + map[i][j]);
    flag[j] = true;
    }
    }
    int main() {
    int a, b, c;
    while(scanf("%d%d", &n, &m) && (n || m)) {
    memset(map, inf, sizeof(map));
    while(m--) {
    scanf("%d%d%d", &a, &b, &c);
    if(map[a][b] > c)
    map[a][b] = map[b][a] = c;
    }
    memset(flag, true, sizeof(flag));
    flag[] = false;
    ans = inf; DFS(, );
    printf("%d\n", ans);
    }
    return ;
    }

HDU-2544-最短路(各种最短路径算法)的更多相关文章

  1. HDU - 2544最短路 (dijkstra算法)

    HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...

  2. hdu 2544 最短路(SPFA算法)

    本题链接:点击打开链接 本题大意: 首先输入一个n,m.代表有n个点.m条边.然后输入m条边,每条边输入两个点及边权.1为起点,n为终点.输入两个零表示结束. 解题思路: 本题能够使用SPFA算法来做 ...

  3. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  4. UESTC 30 &&HDU 2544最短路【Floyd求解裸题】

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  5. hdu 2544 最短路(两点间最短路径)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2544 方法一:dijkstra算法,求两点之间最短路径. /*********************** ...

  6. HDU 2544最短路 (迪杰斯特拉算法)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Time Limit: 5000/1000 MS (Java/Others)    Me ...

  7. hdu 2544 最短路

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shi ...

  8. 题解报告:hdu 2544 最短路

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t ...

  9. (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。

    floyd解法 今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂. 模版题,纯练打字... HDU 1874: #include <cstdio> #define MAXN ...

  10. hdu 2544 最短路 (最短路径)

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

随机推荐

  1. SQL基础教程(第2版)第2章 查询基础:练习题

    SELECT product_name, regist_date FROM Product WHERE regist_date > '2009-04-28'; ① ~ ③中的 SQL 语句都无法 ...

  2. 「不会」Min25筛

    大概的思路是把所有数分成质数和合数考虑 对于质数,必须找出一个很简单的完全积性函数和所求函数拟合 把所有数当做质数看待求个前缀和,然后再枚举合数的最小质因子把合数T掉 枚举到根号n,即可保证把n以内的 ...

  3. [转载]matlab视频读取函数VideoReader

    看到以前matlab中读取视频多 使用mmreader等(参考<matlab读取/播放视频的函数>),而现在matlab有一个专门的视频读取类VideoReader完成视频读取的功能. 相 ...

  4. gff文件提取cds

    #!/usr/bin/perl use strict; use warnings; ########input######## ];my $cut = &cut($gff);my %cut = ...

  5. 嵌入式linux学习笔记

    1.溢出:两个数相加,如果最高位的进位和此高位的进位不同,则产生溢出. 2.进位和溢出的概念不一样. 3.预取(取得是编译后得到的机器代码)-->译码-->执行 4.ARM的汇编指令长度是 ...

  6. js等于符号的详解

    JavaScript == 与 === 区别 1.对于 string.number 等基础类型,== 和 === 是有区别的 a)不同类型间比较,== 之比较 "转化成同一类型后的值&quo ...

  7. python文件读写 文件修改

    #设置一个变量f为文件对象,并打开文件#写文件#f = open('user.txt','w',encoding='utf-8') #f是一个文件对象f=open(r'c:\Users\PL\Desk ...

  8. python 多维数组 字典

    #多维数组list = [[87,57,98],[34,87,90]]print(list[1][0]) l = [[87,57,98],[34,87,[90,99,67]]]print(l[1][2 ...

  9. 启动查看crontab日志服务

    方法1: . 修改rsyslog文件,将/etc/rsyslog.d/-default.conf 文件中的#cron.*前的#删掉: . 重启rsyslog服务service rsyslog rest ...

  10. Nginx_安全2

    Nginx与安全有关的配置 隐藏版本号 http {    server_tokens off;} 经常会有针对某个版本的nginx安全漏洞出现,隐藏nginx版本号就成了主要的安全优化手段之一,当然 ...