codevs 1173 最优贸易(DP+SPFA运用)
/*
中国的题目 ——贱买贵卖 0.0
这题wa了好多遍
第一遍看着题 哎呀这不很简单嘛 从起点能到的点都是合法的点
然后统计合法的点里最大最小值 然后printf
也不知道哪里来的自信 就这么交了 然后爆零了
第二遍想了想 恩 刚开始思路有问题 必须先买后卖
买的点要在卖的前面 恩 很有道理
然后数组模拟着统计了一下i之前的最小值和i之后的最大值
并且确保每个点都是合法的
然后 连样例都不对了.....
第三遍 终于找到了问题的关键(好吧我是看到标签里有spfa才想到了)
因为他是图啊 图啊 而且是有向的 而且有双向边
这个嘛 当然还是跑一遍这个图 按照跑的顺序更新最大最小值
所以正反建边 正反分别跑最大最小就ok了
下面是wa的代码
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 500010
using namespace std;
int n,m,num,head[maxn],v[maxn],sm[maxn],bi[maxn];
bool f[maxn];
struct node
{
int v,pre;
}e[maxn*];
int init()
{
int x=;char s=getchar();
while(s<''||s>'')s=getchar();
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x;
}
void Add(int from,int to)
{
num++;
e[num].v=to;
e[num].pre=head[from];
head[from]=num;
}
void Dfs(int s)
{
for(int i=head[s];i;i=e[i].pre)
if(f[e[i].v]==)
{
f[e[i].v]=;
Dfs(e[i].v);
}
}
void Get_sb()
{
sm[]=maxn;
for(int i=;i<=n;i++)sm[i]=min(v[i],sm[i-]);
for(int i=n;i>=;i--)bi[i]=max(v[i],bi[i-]);
}
int main()
{
n=init();m=init();
for(int i=;i<=n;i++)
v[i]=init();
int x,y,z;
for(int i=;i<=m;i++)
{
x=init();y=init();z=init();
if(z==)Add(x,y);
else Add(x,y),Add(y,x);
}
f[]=;Dfs();
Get_sb();
int minn=0x3f3f3f3f,maxx=;
for(int i=;i<=n;i++)
if(f[i])
{
minn=min(minn,bi[i]-sm[i]);
maxx=max(maxx,bi[i]-sm[i]);
}
printf("%d\n",maxx-minn);
return ;
}
/*这是Ac的代码*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define maxn 500010
using namespace std;
int n,m,num,num2,head[maxn],head2[maxn],v[maxn],dx[maxn],dy[maxn],ans;
bool f[maxn];
struct node
{
int v,pre;
}e[maxn*],e2[maxn*];
int init()
{
int x=;char s=getchar();
while(s<''||s>'')s=getchar();
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x;
}
void Add(int from,int to)
{
num++;
e[num].v=to;
e[num].pre=head[from];
head[from]=num;
}
void Add2(int from,int to)
{
num2++;
e2[num2].v=to;
e2[num2].pre=head2[from];
head2[from]=num2;
}
void SPFA(int s)
{
memset(dx,/,sizeof(dx));
f[s]=;dx[s]=v[s];
queue<int>q;
q.push(s);
while(!q.empty())
{
int k=q.front();q.pop();
for(int i=head[k];i;i=e[i].pre)
{
dx[e[i].v]=min(dx[e[i].v],min(v[e[i].v],dx[k]));
if(f[e[i].v]==)
{
f[e[i].v]=;
q.push(e[i].v);
}
}
}
}
void SPFA2(int s)
{
f[s]=;dy[s]=v[s];
queue<int>q;
q.push(s);
while(!q.empty())
{
int k=q.front();q.pop();
for(int i=head2[k];i;i=e2[i].pre)
{
dy[e2[i].v]=max(dy[e2[i].v],max(v[e2[i].v],dy[k]));
if(f[e2[i].v]==)
{
f[e2[i].v]=;
q.push(e2[i].v);
}
}
}
}
int main()
{
n=init();m=init();
for(int i=;i<=n;i++)
v[i]=init();
int x,y,z;
for(int i=;i<=m;i++)
{
x=init();y=init();z=init();
if(z==)Add(x,y),Add2(y,x);
else Add(x,y),Add(y,x),Add2(x,y),Add2(y,x);
}
SPFA();memset(f,,sizeof(f));SPFA2(n);
int minn=0x3f3f3f3f,maxx=;
for(int i=;i<=n;i++)
ans=max(ans,dy[i]-dx[i]);
printf("%d\n",ans);
return ;
}
codevs 1173 最优贸易(DP+SPFA运用)的更多相关文章
- Codevs 1173 最优贸易 2009年NOIP全国联赛提高组
1173 最优贸易 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description [问题描述] C 国有n ...
- 【题解】洛谷P1073 [NOIP2009TG] 最优贸易(SPFA+分层图)
次元传送门:洛谷P1073 思路 一开始看题目嗅出了强连通分量的气息 但是嫌长没打 听机房做过的dalao说可以用分层图 从来没用过 就参考题解了解一下 因为每个城市可以走好几次 所以说我们可以在图上 ...
- 洛谷P1073 最优贸易 [图论,DP]
题目传送门 最优贸易 题目描述 C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路,一部分为双向 ...
- P1073 最优贸易 建立分层图 + spfa
P1073 最优贸易:https://www.luogu.org/problemnew/show/P1073 题意: 有n个城市,每个城市对A商品有不同的定价,问从1号城市走到n号城市可以最多赚多少差 ...
- 洛谷 P1073 最优贸易 最短路+SPFA算法
目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 题面 题目链接 P1073 最优贸易 题目描述 C国有 $ n $ 个大城市和 ...
- 洛谷 P1073 最优贸易 解题报告
P1073 最优贸易 题目描述 \(C\)国有\(n\)个大城市和\(m\)条道路,每条道路连接这\(n\)个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这\(m\)条道路中有一部分 ...
- NOIP2009 最优贸易
3. 最优贸易 (trade.pas/c/cpp) [问题描述] C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间 多只有一条道路直接相连.这 m 条道 ...
- Luogu P1073 最优贸易
题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双 ...
- [Luogu 1073] NOIP2009 最优贸易
[Luogu 1073] NOIP2009 最优贸易 分层图,跑最长路. 真不是我恋旧,是我写的 Dijkstra 求不出正确的最长路,我才铤而走险写 SPFA 的- #include <alg ...
随机推荐
- Java学习----设计正真的应用程序
import java.util.Scanner; // 输入10位学生的成绩,并且判断他们的成绩是哪个等级,其中90-100是A级,80-89是B级,70-79是C级,60-69是D级,60分以下E ...
- 织梦dedecms网站六大SEO优化技巧(转帖)
一个排名好的网站离不开好的cms,当然不同cms各有各的好处,因此我们在上线新网站的时候,要针对不同的情况因地制宜,选择不同的网站管理系统来做seo优化,现在使用比较流行的cms是织梦dedecms, ...
- PHP图形计算器(计算三角形矩形周长面积)
运用PHP面向对象的知识设计一个图形计算器,同时也运用到了抽象类知识,这个计算器可以计算三角形的周长和面积以及矩形的周长和面积.本图形计算器有4个页面:1.PHP图形计算器主页index.php; ...
- python学习之旅:array 转 list
最近学习python,记录学习的点滴. >>> import numpy as np >>> a = np.array([[1,2],[3,4]]) >> ...
- 使用Intellij IDEA构建spark开发环境
近期开始研究学习spark,开发环境有多种,由于习惯使用STS的maven项目,但是按照许多资料的方法尝试以后并没有成功,也可能是我环境问题:也可以是用scala中自带的eclipse,但是不太习惯, ...
- python3和Python2的区别(被坑太久了)
print函数:(Python3中print为一个函数,必须用括号括起来:Python2中print为class) Python 2 的 print 声明已经被 print() 函数取代了,这意味着我 ...
- Xcode export/upload error: Your session has expired. Please log in-b
1.Xcode export/upload error: Your session has expired. Please log in 我在stack over flow上找到的答案: 一看pre ...
- linux命令之文件、文件夹操作
文件 创建文件 touch fileName 拷贝文件 基本形式: cp source destination tips: 1) 将文件拷贝纸当前目录 cp source . 2)常用参数 -R -r ...
- EMV规范 ---ISO7816 T=0协议的时间特性
复位应答期间: 字符间的时间间隔最小是12etu,最大是9600etu,但整个ATR不得超过19200etu(TS的起始沿到最后一个字符的起始沿 从卡片发出的连续字符其最小时间间隔为12etu,但是终 ...
- 【HDOJ】1109 Run Away
基础模拟退火. /* poj 1379 */ #include <iostream> #include <cstdio> #include <cstdlib> #i ...