题目描述

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

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

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

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

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

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

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

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

输入输出格式

输入格式:

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

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

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

输出格式:

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

输入输出样例

输入样例#1: 复制

5 5
4 3 5 6 1
1 2 1
1 4 1
2 3 2
3 5 1
4 5 2
输出样例#1: 复制

5

说明

【数据范围】

输入数据保证 111 号城市可以到达n n n号城市。

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

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

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

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

水晶球价格≤100≤100≤100。

NOIP 2009 提高组 第三题

题解:

题目大意就是求出来最大价格差,所以要先求一下在最短路期间的的每一条路上路过的城市的最小值,求完之后还要再求一下每条路上的路过城市的最大值

要注意这个两次最短路期间求极值的时候我们要一个选择城市的路径按题目上给出的,另一个要把存路径的数组中的道路反过来

为什么要这样?

正着求一次表示每一次从起点开始的路径到达这一条路上的某个城市的时候,加上之前经过的这条路上的所有城市中目前价格最低的

反着题目给出的路径这一种求最大值的最短路,意思是从终点开始的每一条路上,这个城市加上之前经过的这条路上的所有城市中目前价格最高的

这个样子如果正着路径经过一个城市,反正路径也经过了那个城市,那就说明可以从起点中途经过这个点到达终点

最后可以对所有的这些点进行枚举来找出价格差最大

具体实现看代码:

  1 #include<cstdio>
2 #include<cstring>
3 #include<iostream>
4 #include<algorithm>
5 #include<vector>
6 #include<queue>
7 using namespace std;
8 typedef long long ll;
9 const int maxn=100005;
10 const int INF=0x3f3f3f3f;
11 struct shudui
12 {
13 int start;
14 }str1,str2;
15 queue<int>r;
16 int v[maxn],d1[maxn],vis[maxn],n,d2[maxn];
17 vector<shudui>w[maxn];
18 vector<shudui>ww[maxn];
19 void spay(int d[maxn])
20 {
21 memset(vis,0,sizeof(vis));
22
23 r.push(1);
24 d[1]=v[1];
25 vis[1]=1;
26 while(!r.empty())
27 {
28 int x=r.front();
29 r.pop();
30 vis[x]=0;
31 for(int i=0;i<w[x].size();++i)
32 {
33 int y=w[x][i].start;
34 if(d[y]>min(d[x],v[y]))
35 {
36 d[y]=min(d[x],v[y]);
37 if(!vis[y])
38 {
39 r.push(y);
40 vis[y]=1;
41 }
42 }
43 }
44 }
45 }
46 void spay2(int d[maxn])
47 {
48 memset(vis,0,sizeof(vis));
49 r.push(n);
50 d[n]=v[n];
51 vis[n]=1;
52 while(!r.empty())
53 {
54 int x=r.front();
55 r.pop();
56 vis[x]=0;
57 for(int i=0;i<ww[x].size();++i)
58 {
59 int y=ww[x][i].start;
60 if(d[y]<max(d[x],v[y]))
61 {
62 d[y]=max(d[x],v[y]);
63 if(!vis[y])
64 {
65 r.push(y);
66 vis[y]=1;
67 }
68 }
69 }
70 }
71 }
72 int main()
73 {
74 int m;
75 scanf("%d%d",&n,&m);
76 for(int i=1;i<=n;++i)
77 scanf("%d",&v[i]);
78 while(m--)
79 {
80 int x,y,z;
81 scanf("%d%d%d",&x,&y,&z);
82 if(z==1)
83 {
84 str2.start=y;
85 w[x].push_back(str2);
86 str2.start=x;
87 ww[y].push_back(str2);
88 }
89 else
90 {
91 str2.start=y;
92 w[x].push_back(str2);
93 str2.start=x;
94 w[y].push_back(str2);
95 str2.start=y;
96 ww[x].push_back(str2);
97 str2.start=x;
98 ww[y].push_back(str2);
99 }
100 }
101 memset(d1,INF,sizeof(d1));
102 //printf("%d\n",d1[1]);
103 spay(d1);
104 memset(d2,0,sizeof(d2));
105 spay2(d2);
106 int maxx=0;
107 for(int i=1;i<=n;++i)
108 {
109 //if(d2[i]!=INF && d1[i]!=0)
110 maxx=max(maxx,d2[i]-d1[i]);
111 }
112 printf("%d\n",maxx);
113 return 0;
114 }

P1073 最优贸易(最短路)的更多相关文章

  1. Luogu P1073 最优贸易(最短路)

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

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

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

  3. 洛谷 P1073 最优贸易 解题报告

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

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

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

  5. 洛谷——P1073 最优贸易

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

  6. P1073 最优贸易 建立分层图 + spfa

    P1073 最优贸易:https://www.luogu.org/problemnew/show/P1073 题意: 有n个城市,每个城市对A商品有不同的定价,问从1号城市走到n号城市可以最多赚多少差 ...

  7. P1073 最优贸易 分层图+最长路

    洛谷p1073 最优贸易 链接 首先易得暴n2的暴力,暴力枚举就行 显然1e5的数据是会炸的 我们再分析题意,发现一共分为两个个步骤,也可以说是状态,即在一个点买入,在另一个点卖出,我们可以构建一个三 ...

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

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

  9. Luogu P1073 最优贸易

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

随机推荐

  1. 借助window.performance实现基本的前端基础性能监控日志

    借助window.performance实现基本的前端基础性能监控日志并二次重写console方法方便日常前端console日志的调试 npm install sn-console

  2. 【C++】《C++ Primer 》第十章

    第十章 泛型算法 一.概述 因为它们实现共同的操作,所以称之为"算法".而"泛型",指的是它们可以操作在多种容器类型上. 泛型算法并不直接操作容器,而是遍历由两 ...

  3. ThinkPHP5表单令牌刷新

    制作登录页面的时候,加入了表单令牌,账号和密码输入错误后,再登录的话,会提示表单令牌错误, 这是因为旧的令牌已经过期了,我们要处理下前端的token,修复的办法,在路由文件下加入 //刷新表单令牌,然 ...

  4. 【Jboss】应用中缺少宋体怎么办

    环境jboss4.2.2 系统CentOS7.2 1.新搭建的环境,但是没有字符集,在windows上的电脑上复制了一份宋体,打成zip包 将zip包上传到服务器中,解压 2.在/usr/share/ ...

  5. 一文读懂k8s之Pod安全策略

    导读 Pod容器想要获取集群的资源信息,需要配置角色和ServiceAccount进行授权.为了更精细地控制Pod对资源的使用方式,Kubernetes从1.4版本开始引入了PodSecurityPo ...

  6. 运行.bat执行sql文件 —— mysql

    参考地址:https://www.cnblogs.com/dingjiaoyang/p/9990188.html 运行test.bat 执行 test.sql文件 test.bat: @ECHO OF ...

  7. Kubernetes集群管理工具kubectl命令技巧大全

    一. kubectl概述 Kubectl是用于控制Kubernetes集群的命令行工具,通过kubectl能够对集群本身进行管理,并能够在集群上进行容器化应用的安装部署. kubectl命令的语法如下 ...

  8. Rancher On K3s 高可用架构部署

    Rancher 推荐部署架构 k3s 模式 RKE 和 k8s 模式 备注: 我对 RKE 的理解就是 Ansible + kubeadm 的打包,首先 rke 需要到每一个节点都可以免密 ssh , ...

  9. C++ unordered_map/unordered_set 自定义键类型

    1. unordered_map 和 unordered_set template < class Key, // unordered_map::key_type class T, // uno ...

  10. Tomcat窗口标题,中文乱码解决方法

    工作中,或多或少的原因,一台服务器中需要同时运行多个Tomcat服务(针对一台服务器如何同时运行多个Tomcat的配置,这里不做论述,百度很多),为了便于区分各个Tomcat的功能,通常会选择修改to ...