P1073 最优贸易

题目描述

\(C\)国有\(n\)个大城市和\(m\)条道路,每条道路连接这\(n\)个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这\(m\)条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的道路在统计条数时也计为1条。

\(C\)国幅员辽阔,各地的资源分布情况各不相同,这就导致了同一种商品在不同城市的价格不一定相同。但是,同一种商品在同一个城市的买入价和卖出价始终是相同的。

商人阿龙来到\(C\)国旅游。当他得知同一种商品在不同城市的价格可能会不同这一信息之后,便决定在旅游的同时,利用商品在不同城市中的差价赚回一点旅费。设\(C\)国\(n\)个城市的标号从\(1\)~ \(n\) ,阿龙决定从1号城市出发,并最终在\(n\)号城市结束自己的旅行。在旅游的过程中,任何城市可以重复经过多次,但不要求经过所有\(n\)个城市。阿龙通过这样的贸易方式赚取旅费:他会选择一个经过的城市买入他最喜欢的商品――水晶球,并在之后经过的另一个城市卖出这个水晶球,用赚取的差价当做旅费。由于阿龙主要是来\(C\)国旅游,他决定这个贸易只进行最多一次,当然,在赚不到差价的情况下他就无需进行贸易。

假设\(C\)国有5个大城市,城市的编号和道路连接情况如下图,单向箭头表示这条道路为单向通行,双向箭头表示这条道路为双向通行。

假设 1~\(n\)号城市的水晶球价格分别为 4,3,5,6,1 。

阿龙可以选择如下一条线路: 1-> 2-> 3 -> 5 ,并在 2 号城市以3 的价格买入水晶球,在3 号城市以 5 的价格卖出水晶球,赚取的旅费数为 2。

阿龙也可以选择如下一条线路1 -> 4 -> 5 -> 4 -> 5 ,并在第 1 次到达 5 号城市时以 1 的价格买入水晶球,在第 2 次到达 4 号城市时以6 的价格卖出水晶球,赚取的旅费数为 5 。

现在给出\(n\)个城市的水晶球价格, \(m\)条道路的信息(每条道路所连接的两个城市的编号以及该条道路的通行情况)。请你告诉阿龙,他最多能赚取多少旅费。

输入输出格式

输入格式:

第一行包含 2个正整数\(n\)和\(m\),中间用一个空格隔开,分别表示城市的数目和道路的数目。

第二行\(n\)个正整数,每两个整数之间用一个空格隔开,按标号顺序分别表示这\(n\)个城市的商品价格。

接下来\(m\)行,每行有\(3\)个正整数\(x,y,z\) ,每两个整数之间用一个空格隔开。如果\(z=1\) ,表示这条道路是城市\(x\)到城市\(y\)之间的单向道路;如果\(z=2\) ,表示这条道路为城市 \(x\)和城市\(y\)之间的双向道路。

输出格式:

一 个整数,表示最多能赚取的旅费。如果没有进行贸易,则输出0 。

说明

输入数据保证 1号城市可以到达\(n\) 号城市。

对于 10%的数据, 1≤n≤6 。

对于 30%的数据, 1≤n≤100。

对于 50%的数据,不存在一条旅游路线,可以从一个城市出发,再回到这个城市。

对于 100%的数据, 1≤n≤100000, 1≤m≤500000, 1≤x1≤x , y≤ny≤n , 1≤z≤2 , 1≤1≤ 各城市

水晶球价格 ≤100。

NOIP 2009 提高组 第三题


这题做法很多,我用到tarjan缩点+TOPO+DP

还有双向spfa,分层图等做法

注意细节:我最开始居然还先卖后买了


Code:

#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
const int N=100010;
const int M=500010;
int n0,n,m,p[N],mx[N],mi[N],ans[N];
int head0[N],to0[M<<1],next0[M<<1],cnt0;
void add0(int u,int v)
{
next0[++cnt0]=head0[u];to0[cnt0]=v;head0[u]=cnt0;
}
int head[N],to[M],next[M],cnt;
void add(int u,int v)
{
next[++cnt]=head[u];to[cnt]=v;head[u]=cnt;
}
int ha[N],time=0,dfn[N],low[N],s[N],tot=0,is[N],in[N];
void tarjan(int now)
{
dfn[now]=low[now]=++time;
s[++tot]=now;
is[now]=1;
for(int i=head0[now];i;i=next0[i])
{
int v=to0[i];
if(!dfn[v])
{
tarjan(v);
low[now]=min(low[now],low[v]);
}
else if(is[v])
low[now]=min(low[now],dfn[v]);
}
if(low[now]==dfn[now])
{
int tmp;
n++;
do
{
tmp=s[tot--];
is[tmp]=0;
ha[tmp]=n;
mx[n]=max(mx[n],p[tmp]);
mi[n]=min(mi[n],p[tmp]);
}while(tmp!=now);
}
}
void New()
{
for(int i=1;i<=n0;i++)
{
if(!ha[i]) continue;
for(int j=head0[i];j;j=next0[j])
{
int v=to0[j];
if(!ha[v]) continue;
if(ha[v]!=ha[i])
{
add(ha[i],ha[v]);
in[ha[v]]++;
}
}
}
}
queue <int > q;
void topo()
{
q.push(ha[1]);
while(!q.empty())
{
int u=q.front();
q.pop();
for(int i=head[u];i;i=next[i])
{
int v=to[i];
in[v]--;
mi[v]=min(mi[v],mi[u]);
ans[v]=max(ans[v],ans[u]);
if(!in[v])
{
if(mx[v]>mi[v])
ans[v]=max(ans[v],mx[v]-mi[v]);
q.push(v);
}
}
}
}
int main()
{
scanf("%d%d",&n0,&m);
memset(mi,0x3f,sizeof(mi));
int typ,u,v;
for(int i=1;i<=n0;i++)
scanf("%d",p+i);
for(int i=1;i<=m;i++)
{
scanf("%d%d%d",&u,&v,&typ);
if(typ==1) add0(u,v);
else add0(u,v),add0(v,u);
}
tarjan(1);
New();
topo();
printf("%d\n",ans[ha[n0]]);
return 0;
}

2018.6.25

洛谷 P1073 最优贸易 解题报告的更多相关文章

  1. 洛谷P1073 最优贸易==codevs1173 最优贸易

    P1073 最优贸易 题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一 ...

  2. 洛谷——P1073 最优贸易

    P1073 最优贸易 n 个城市间以 m 条有向道路连接, 小 T 从 1 号城市出发, 将要去往 n 号城市.小 T 观察到一款商品 Z 在不同的城市的价格可能不尽相同,小 T 想要在旅行中的某一个 ...

  3. 洛谷 P1073 最优贸易 最短路+SPFA算法

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 题面 题目链接 P1073 最优贸易 题目描述 C国有 $ n $ 个大城市和 ...

  4. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  5. 洛谷P1073 最优贸易 [图论,DP]

    题目传送门 最优贸易 题目描述 C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路,一部分为双向 ...

  6. 洛谷 P1073 最优贸易 & [NOIP2009提高组](反向最短路)

    传送门 解题思路 很长的题,实际上在一个有向图(点有点权)中求一个从起点1到终点n的路径,使得这条路径上点权最大的点与点权最小的点的差值最大(要求必须从点权较小的点能够走到点权较大的点). ——最短路 ...

  7. [NOIP2009] 提高组 洛谷P1073 最优贸易

    题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分 为双向通行的道路 ...

  8. 洛谷 P1073 最优贸易

    题目描述 CC C 国有 n n n 个大城市和 m mm 条道路,每条道路连接这 nnn 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 mmm 条道路中有一部分为单向通行的道路 ...

  9. NOIP2009 codevs1173 洛谷P1073 最优贸易

    Description: 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通 ...

随机推荐

  1. Flutter - 自动引用pub.dartlang.org/packages上最新的packages

    一般在pubspec.yaml里面引用pub.dartlang.org/packages的packages时,我们都是在包名称后面加上版本号的,谷歌默认也是这样写的. cupertino_icons: ...

  2. XAMPP、PHPstorm和PHPcharm和Windows环境下Python搭建+暴力破解

    XAMPP的安装和使用 一.什么是XAMPP? XAMPP是最流行的PHP开发环境. XAMPP是完全免费且易于安装的Apache发行版,其中包含Apache.MariaDB.PHP和Perl. 类似 ...

  3. # 《网络对抗》Exp1 PC平台逆向破解20155337祁家伟

    <网络对抗>Exp1 PC平台逆向破解20155337祁家伟 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会 ...

  4. MVVM Light Toolkit使用指南

    原文:MVVM Light Toolkit使用指南 原文地址:  https://blog.csdn.net/ldld1717/article/details/77040077 概述 MVVM Lig ...

  5. Luogu P1558 色板游戏

    (此题与POJ2777重题) 为了加深对线段树的记忆,然后开始搞这道题. TM的WA了一下午就是发现x可能大于y(然而题目里说的还很清楚,我TM没看见) 这道题只需要在线段树的板子上改一些地方就可以了 ...

  6. 论FPGA建模,与面向对象编程的相似性

    很久没有写FPGA方面的博客了,因为最近一直在弄一个绘图的上位机. 我觉得自己建模思想还不错,但是面向对象思维总是晕的.突然有一天发现,两者居然有这么对共同之处,完全可以相互启发啊.就简单聊下. 1. ...

  7. Hadoop日记Day5---HDFS介绍

    一.HDFS介绍 1.1 背景 随着数据量越来越大,在一个操作系统管辖的范围存不下了,那么就分配到更多的操作系统管理的磁盘中,但是不方便管理和维护,迫切需要一种系统来管理多台机器上的文件,这就是分布式 ...

  8. 【第十三课】监控Linux系统状态

    目录 1.查看系统负载命令:w.uptime 2.vmstat详解 3.top动态查看负载 4.sar命令(监控网卡流量) 5.nload命令(监控网卡流量) 6.iostat iotop(监控IO性 ...

  9. HTML基础之HTML标签

    前端的三把利器 HTML:赤裸的一个人 CSS:华丽的衣服 JS/JavaScript:赋予这个人的行为,也就是动起来 HTML(超文本标记语言) html代码实际上就是一套能够被浏览器所识别的规则代 ...

  10. JQ_下雪特效

    这是一个jQuery下雪特效.特效的代码如下: <style>body{background:black;color:white}</style><script>/ ...