热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

51nod3221祝寿(反向建图优化)

题目链接感觉忘记了好多东西。求有向图中其余点到一个点的最短距离可以将该图翻转后rundijkstra#include#include

题目链接
在这里插入图片描述
感觉忘记了好多东西。 求有向图中其余点到一个点的最短距离可以将该图翻转后run dijkstra

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define ll long long
#define int long long
#define inf 0x3f3f3f3f
#define mods 1000000007
#define modd 998244353
#define PI acos(-1)
#define fi first
#define se second
#define lowbit(x) (x&(-x))
#define mp make_pair
#define pb push_back
#define si size()
#define E exp(1.0)
#define fixed cout.setf(ios::fixed)
#define fixeds(x) setprecision(x)
#define IOS ios::sync_with_stdio(false);cin.tie(0)using namespace std;ll gcd(ll a,ll b){if(a<0)a&#61;-a;if(b<0)b&#61;-b;return b&#61;&#61;0?a:gcd(b,a%b);}
template<typename T>void read(T &res){bool flag&#61;false;char ch;while(!isdigit(ch&#61;getchar()))(ch&#61;&#61;&#39;-&#39;)&&(flag&#61;true);
for(res&#61;ch-48;isdigit(ch&#61;getchar());res&#61;(res<<1)&#43;(res<<3)&#43;ch - 48);flag&&(res&#61;-res);}
ll lcm(ll a,ll b){return a*b/gcd(a,b);}
ll qp(ll a,ll b,ll mod){ll ans&#61;1;if(b&#61;&#61;0){return ans%mod;}while(b){if(b%2&#61;&#61;1){b--;ans&#61;ans*a%mod;}a&#61;a*a%mod;b&#61;b/2;}return ans%mod;}//快速幂%
ll qpn(ll a,ll b, ll p){ll ans &#61; 1;a%&#61;p;while(b){if(b&1){ans &#61; (ans*a)%p;--b;}a &#61;(a*a)%p;b >>&#61; 1;}return ans%p;}//逆元 (分子*qp(分母,mod-2,mod))%mod;const int manx&#61;1e4&#43;500;
const int mamx&#61;2e5&#43;5;ll head[3][manx],d[3][manx];
bool vis[3][manx];ll n,m,s,e,kk,ans;
ll k[3];struct node{ll v,next,w;
}a[3][mamx];
void add(ll u,ll v,ll w,ll pos)
{a[pos][&#43;&#43;k[pos]].next&#61;head[pos][u];a[pos][k[pos]].w&#61;w;a[pos][k[pos]].v&#61;v;head[pos][u]&#61;k[pos];
}
void dij(ll pos)
{memset(d[pos],inf,sizeof(d[pos]));// memset(vis[pos],0,sizeof(vis[pos]));d[pos][s]&#61;0;priority_queue<pair<ll,ll> >q;q.push(mp(0,s));while(q.size()){ll u&#61;q.top().se;q.pop();// if(vis[u]&&u&#61;&#61;s)return ;if(vis[pos][u]) continue;vis[pos][u]&#61;1;for(int i&#61;head[pos][u];i;i&#61;a[pos][i].next){ll v&#61;a[pos][i].v,w&#61;a[pos][i].w;if(d[pos][v]>d[pos][u]&#43;w){//printf("qwq %lld\n",d[v]); //松弛操作&#xff0c;更新距离d[pos][v]&#61;d[pos][u]&#43;w;// printf("sad %lld %lld %lld %lld\n",d[u],u,res,d[v]);q.push(mp(-d[pos][v],v)); //把更新的距离和点入队&#xff0c;这里距离取负变成小根堆}}}
}ll now[11111];
signed main(){read(n);read(m);ll pos;read(pos);for(int i&#61;1;i<&#61;m;i&#43;&#43;){ll x,y,z;read(x);read(y);read(z);add(x,y,z,2);add(y,x,z,1);}s&#61;pos;dij(2);// k&#61;0;dij(1);for(int i&#61;1;i<&#61;n;i&#43;&#43;){//printf("Q%lld %lld\n",d[2][i],d[1][i]);if(d[2][i]&#43;d[1][i]<inf){printf("%lld\n",d[2][i]&#43;d[1][i]);continue;}printf("impossible\n");}}

推荐阅读
  • 本文详细解析 Skynet 的启动流程,包括配置文件的读取、环境变量的设置、主要线程的启动(如 timer、socket、monitor 和 worker 线程),以及消息队列的实现机制。 ... [详细]
  • 本文详细介绍了Oracle RMAN中的增量备份机制,重点解析了差异增量和累积增量备份的概念及其在不同Oracle版本中的实现。通过对比两种备份方式的特点,帮助读者选择合适的备份策略。 ... [详细]
  • 本题要求计算从起点到终点所有最短路径的总权重,使用SPFA算法进行求解。 ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 题面:P3178[HAOI2015]树上操作好像其他人都嫌这道题太容易了懒得讲,好吧那我讲。题解:第一个操作和第二个操作本质上是一样的&# ... [详细]
  • STM32代码编写STM32端不需要写关于连接MQTT服务器的代码,连接的工作交给ESP8266来做,STM32只需要通过串口接收和发送数据,间接的与服务器交互。串口三配置串口一已 ... [详细]
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • 本文提供了一个关于AC自动机(Aho-Corasick Algorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(fail pointer)来提高字符串匹配效率。 ... [详细]
  • 本文详细探讨了HihoCoder平台上的1398号问题——最大权闭合子图的求解方法。通过具体实例,深入分析了最大权闭合子图的概念及其算法实现。 ... [详细]
  • 本文详细介绍了在Luat OS中如何实现C与Lua的混合编程,包括在C环境中运行Lua脚本、封装可被Lua调用的C语言库,以及C与Lua之间的数据交互方法。 ... [详细]
  • 利用Node.js实现PSD文件的高效切图
    本文介绍了如何通过Node.js及其psd2json模块,快速实现PSD文件的自动化切图过程,以适应项目中频繁的界面更新需求。此方法不仅提高了工作效率,还简化了从设计稿到实际应用的转换流程。 ... [详细]
  • 本文详细介绍了Socket在Linux内核中的实现机制,包括基本的Socket结构、协议操作集以及不同协议下的具体实现。通过这些内容,读者可以更好地理解Socket的工作原理。 ... [详细]
  • LeetCode 102 - 二叉树层次遍历详解
    本文详细解析了LeetCode第102题——二叉树的层次遍历问题,提供了C++语言的实现代码,并对算法的核心思想和具体步骤进行了深入讲解。 ... [详细]
  • 网络流24题——试题库问题
    题目描述:假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算 ... [详细]
  • td{border:1pxsolid#808080;}参考:和FMX相关的类(表)TFmxObjectIFreeNotification ... [详细]
author-avatar
手机用户2502913993
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有