热门标签 | 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");}}

推荐阅读
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
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社区 版权所有