【题解】洛谷P1073 [NOIP2009TG] 最优贸易(SPFA+分层图)
次元传送门:洛谷P1073
思路
一开始看题目嗅出了强连通分量的气息 但是嫌长没打 听机房做过的dalao说可以用分层图 从来没用过 就参考题解了解一下
因为每个城市可以走好几次 所以说我们可以在图上随意走动
所以第一层图就建一个边权为0的图 随意走动不影响
考虑在某个点买入水晶球
建立一条有向边到新图上 边权为-w[i] 指向i所能到达的点(第二层图中)
它表示:假如我选择走了这条边,就是我在这个点买了这个水晶球,我不会反悔,并且我接下来考虑在某个点卖它。
考虑在某个点卖出水晶球
从第二层图建立一条有向边到新图中 边权为w[i] 指向i所能到达的点(第三层图中)
它表示:假如我选择走了这条边,就是我在这个点卖了这个水晶球,我不会反悔,并且我接下来考虑走向终点。
现在我们只需要从第一层图走到第二层图再走到第三层图再走到终点即可 而且分层图把所有情况考虑到了
走向终点有两种情况
- 不买卖直接走向终点 在第一层图的终点连一条有向边 边权为0 到最后终点
- 要买卖再走向终点 在第三层图的终点连一条有向边 边权为0 到最后终点
由于有向边的建立,你不能从第二/三层走回第一层图,这保证了你只做一次买卖,而不是无限做买卖,符合了题目的要求(分层图的意义)
而我们最终的答案 就是求从第一层图的1号点 经过三层图走到“最后终点”的最长路
来自你谷dalao的图解:

代码
#include<iostream>
#include<vector>
#include<queue>
using namespace std;
#define maxn 100010
#define INF 1e9+7
struct Edge
{
int v;
int len;
};
int n,m;
bool vis[maxn*+];
int w[maxn],dis[maxn*+];
vector <Edge> G[maxn*+];
void spfa()//常规SPFA
{
for(int i=;i<=n;i++) dis[i]=-INF;
queue <int> q;
q.push();
dis[]=;
vis[]=;
while(!q.empty())
{
int u=q.front();
q.pop();
vis[u]=;
for(int i=;i<G[u].size();i++)
{
Edge x=G[u][i];
if(dis[x.v]<dis[u]+x.len)
{
dis[x.v]=dis[u]+x.len;
if(!vis[x.v])
{
vis[x.v]=;
q.push(x.v);
}
}
}
}
}
void add(int u,int v)
{
G[u].push_back((Edge){v,});//第一层
G[n+u].push_back((Edge){n+v,});//第二层 用n+1到2*n
G[*n+u].push_back((Edge){*n+v,});//第三层 用2*n+1到3*n
G[u].push_back((Edge){n+v,-w[u]});//从第一层到第二层
G[u+n].push_back((Edge){*n+v,w[u]});//从第二层到第三层
}
int main()
{
cin>>n>>m;
for(int i=;i<=n;i++) cin>>w[i];
for(int i=;i<=m;i++)
{
int x,y,z;
cin>>x>>y>>z;
add(x,y);
if(z==) add(y,x);
}
G[n].push_back((Edge){*n+,});//第一层终点到最后终点
G[*n].push_back((Edge){*n+,});//第三层终点到最后终点
n=*n+;//更改最后终点
spfa();
cout<<dis[n];
}
【题解】洛谷P1073 [NOIP2009TG] 最优贸易(SPFA+分层图)的更多相关文章
- 【洛谷P1073】最优贸易
题目大意:给定一个 N 个点,M 条边(存在反向边)的有向图,点有点权,求一条从 1 到 N 的路径上,任意选出两个点 p,q (p 在前,q在后),两点点权的差值最大. 根据最短路的 dp 思想,可 ...
- 【洛谷 P1073】 最优贸易 (Tarjan缩点+拓扑排序)
题目链接 先\(Tarjan\)缩点,记录每个环内的最大值和最小值. 然后跑拓扑排序,\(Min[u]\)表示到\(u\)的最小值,\(ans[u]\)表示到\(u\)的答案,\(Min\)和\(an ...
- P1073 最优贸易 建立分层图 + spfa
P1073 最优贸易:https://www.luogu.org/problemnew/show/P1073 题意: 有n个城市,每个城市对A商品有不同的定价,问从1号城市走到n号城市可以最多赚多少差 ...
- 洛谷1073 NOIP2009 最优贸易
题目大意 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双 ...
- [luogu1073 Noip2009] 最优贸易 (dp || SPFA+分层图)
传送门 Description C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路,一部分 为 ...
- 洛谷 P1073 最优贸易 解题报告
P1073 最优贸易 题目描述 \(C\)国有\(n\)个大城市和\(m\)条道路,每条道路连接这\(n\)个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这\(m\)条道路中有一部分 ...
- 洛谷P1073 最优贸易 [图论,DP]
题目传送门 最优贸易 题目描述 C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路,一部分为双向 ...
- 【洛谷P1073】[NOIP2009]最优贸易
最优贸易 题目链接 看题解后感觉分层图好像非常NB巧妙 建三层n个点的图,每层图对应的边相连,权值为0 即从一个城市到另一个城市,不进行交易的收益为0 第一层的点连向第二层对应的点的边权为-w[i], ...
- 洛谷P1073 最优贸易==codevs1173 最优贸易
P1073 最优贸易 题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一 ...
随机推荐
- hdu 2049 考新郎
假设一共有N对新婚夫妇,其中有M个新郎找错了新娘,求发生这种情况一共有多少种可能. 和之前那道题一样,是错排,但是要乘上排列数. 选对的人有C(N,M)个组合,将它们排除掉,剩下的人就是错排了 #in ...
- k:特殊的线性表—队列
队列的概念: 队列是另一种特殊的线性表,它的特殊性体现在其只允许在线性表的一端插入数据元素,在线性表的另一端删除数据元素(一般会采用在线性表的表尾那端(没被head指针所指的那端)插入数据元素,在线 ...
- CentOS-Linux系统下安装MySQL
一.mysql的安装 Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器.基于RPM包管理,能够 ...
- sql:Mysql create view,function,procedure
create database Liber; use Liber; #顯示數据庫 20150210 Geovin Du 涂聚文 SHOW DATABASES; drop table BookKindL ...
- c# copy类中值到另外一个对象中
贴图: 调用:
- Java 之集合框架 上(9)
Java 中的集合框架 如果一个类中存在很多相同类型的属性. 例如:学生类 学生可以选课,因此存在很多课程类型的属性.但是每个学生选择的课程的种类和数量是不一样的. 如果将每一个课程类型的属性都列到课 ...
- Visual Studio解决方案vs2005/vs2008/vs2010/vs2012/vs2013/vs2015版本互相转换工具
原文:http://blog.csdn.net/xiejiashu/article/details/52397641 本文转自EasyDarwin团队成员Alex的博客:http://blog.c ...
- 安卓app开发-01-开发工具及环境配置
安卓app开发-01-开发工具及环境配置 请大家根据推荐指数和自己的意愿选择 使用 Android Studio 1.可以使用 Android Studio 下载地址:http://www.andro ...
- Node.js 常用 API
Node.js v6.11.2 Documentation(官方文档) Buffer Prior to the introduction of TypedArray in ECMAScript 20 ...
- 京东原来你运用的这玩意,不错,我也要!! ContainerDNS
转自社区 ContainerDNS 本文介绍的 DNS 命名为 ContainerDNS,作为京东商城软件定义数据中心的关键基础服务之一,具有以下特点: 分布式,高可用 自动发现服务域名 后端探活 易 ...