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. Android WebView漏洞(转)

    一.漏洞描述 近期,微信等多款安卓流行应用曝出高危挂马漏洞:只要点击好友消息或朋友圈中的一条网址,手机就会自动执行黑客指令,出现被安装恶意扣费软件.向好友 发送欺诈短信.通讯录和短信被窃取等严重后果. ...

  2. 20155227《网络对抗》Exp7 网络欺诈防范

    20155227<网络对抗>Exp7 网络欺诈防范 实践内容(3.5分) 本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法.具体实践有 (1)简单应用SET工具建 ...

  3. 20155238 Java第13周课堂实践

    类定义 实验内容及要求 设计并实现一个Book类,定义义成Book.java,Book 包含书名,作者,出版社和出版日期,这些数据都要定义getter和setter.定义至少三个构造方法,接收并初始化 ...

  4. 20155306 白皎 0day漏洞——漏洞的复现

    一.Ubuntu16.04 (CVE-2017-16995) 1.漏洞概述 Ubuntu最新版本16.04存在本地提权漏洞,该漏洞存在于Linux内核带有的eBPF bpf(2)系统调用中,当用户提供 ...

  5. CodeForces-1155D Beautiful Array

    Description You are given an array \(a\) consisting of \(n\) integers. Beauty of array is the maximu ...

  6. SSIS 连接数据

    通常情况下,ETL方案需要同时访问两个或多个数据源,并把结果合并为单个数据流,输出到目标表中.为了向目标表中提供统一的数据结构,需要把多个数据源连接在一起.数据连接的另外一种用法,就是根据现有的数据, ...

  7. 【Android UI设计与开发】第03期:引导界面(三)仿微信引导界面以及动画效果

    基于前两篇比较简单的实例做铺垫之后,这一篇我们来实现一个稍微复杂一点的引导界面的效果,当然也只是稍微复杂了一点,对于会的人来说当然还是so easy!正所谓会者不难,难者不会,大概说的就是这个意思了吧 ...

  8. 怎么用JavaScript写一个区块链?

    几乎所有语言都可以编写区块链开发程序.那么如何用JavaScript写一个区块链?以下我将要用JavaScript来创建1个简单的区块链来演示它们的内部到底是怎样工作的.我将会称作SavjeeCoin ...

  9. eclipse实现热部署和热启动

    不用每次修改一个class文件就要重启tomcat这么麻烦: http://blog.csdn.net/fuzhongyu2/article/details/52073050

  10. 作业一_随笔1_初来乍到:学号&博客地址

    031302540——http://www.cnblogs.com/yyj031302540/ 计算机实验班叶艺洁