博客
关于我
MPI Maelstrom POJ - 1502
阅读量:280 次
发布时间:2019-03-01

本文共 1777 字,大约阅读时间需要 5 分钟。

??????????????????????1????????????????????Floyd?Dijkstra?Bellman-Ford?Spfa???????Spfa????????Spfa????????????????#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define ll long long#define PI acos(-1)#define mes(x,y) memset(x,y,sizeof(x))#define lp pair
#define FAST_IO ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)using namespace std;const ll inf = 10000000000000005;ll n, m, i, j, k = 0, t, w, flag, x, y, z, sum;string s1, s2, s;struct node { ll end, len; node(ll x, ll y) : end(x), len(y) {}};vector
v;ll dis[110];ll ismove[110];ll StrTurnNum(string s) { sum = 0; ll i = 0; while (i < s.length()) { sum = (ll)(s[i++] - '0') + sum * 10; } return sum;}ll Spfa(ll beginkind) { mes(dis, inf); mes(ismove, 0); queue
que; dis[beginkind] = 0; que.push(beginkind); while (!que.empty()) { t = que.front(); que.pop(); ismove[t] = 0; for (i = 0; i < v[t].size(); i++) { if (dis[v[t][i].end] > dis[t] + v[t][i].len) { dis[v[t][i].end] = dis[t] + v[t][i].len; if (ismove[v[t][i].end] == 0) { que.push(v[t][i].end); ismove[v[t][i].end] = 1; } } } } for (i = 2, j = dis[1]; i <= n; i++) { j = max(j, dis[i]); } return j;}int main() { cin >> n; for (i = 2; v.resize(n+1); i++) { for (j = 1; j < i; j++) { cin >> s; if (s == "x") continue; else { v[i].push_back(node(j, StrTurnNum(s))); v[j].push_back(node(i, StrTurnNum(s))); } } } cout << Spfa(1) << endl; return 0;}

?????

  • ?????????????????????????????????
  • ?????????node??????????end?len?????????????
  • ???Spfa??????????
  • StrTurnNum??????????????
  • Spfa?????Spfa?????????????????
  • main??????????????????Spfa??1??????????????
  • ?????????????????????????????

    转载地址:http://qmvo.baihongyu.com/

    你可能感兴趣的文章
    PHPExcel一些基本设置总结
    查看>>
    phpexcel中文手册
    查看>>
    PHPExcel导入导出 若在thinkPHP3.2中使用(无论实例还是静态调用(如new classname或classname::function)都必须加反斜杠,因3.2就命名空间,如/c...
    查看>>
    phpize及其用法
    查看>>
    phpMailer发送邮件
    查看>>
    PHPMailer发送邮件
    查看>>
    phpmailer发送邮件,可以带附件
    查看>>
    phpmailer的用法
    查看>>
    phpMQTT
    查看>>
    phpmyadmin 安装
    查看>>
    phpmyadmin导出数据库出现Fatal error: Cannot 'break' 2 levels in D:\phpstudy\WWW\phpMyAdmin
    查看>>
    phpmyadmin数据库建表及插入
    查看>>
    phpnow配置
    查看>>
    phprpc简单使用
    查看>>
    phpspider中当爬虫获取数据时如何去掉广告
    查看>>
    phpstorm 2016.3.3 激活
    查看>>
    phpstorm中Xdebug的使用
    查看>>
    phpstorm中使用svn版本控制器
    查看>>
    phpstorm配置php脚本执行
    查看>>
    PhpStorm配置远程xdebug
    查看>>