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解析JSON (使用net.sf.json)
例如JSON字符串str如下: { "data": [ { "basic_title": "运筹帷幄因 ...
- websphere节点、单元、服务之间的关系
单元(cell).节点(node).概要文件(profile).服务(server) 在websphere集群(ND版本)模式下: 一个cell单元可以包含多个node节点,node=profile, ...
- 【行为型】Strategy模式
策略模式意图将解决问题的算法分别封装成一个个对象的形式,并使这些算法对象相互间可被替换.模式比较简单,对于策略对象结构的设计,可抽象一个抽象基类,并定义好相关算法(纯)虚接口,并由各种具体的实现算法子 ...
- 一个jpa动态模糊查询的实现
最近一直在是用spring data jpa,使用起来确实方便,如果是单表的操作基本上通过方法名都可以实现,下面是一个 Specification 实现动态模糊查询的例子这个查询是通过JpaSpeci ...
- python urllib2
http://my.oschina.net/duhaizhang/blog/69883
- 托管host
托管在googlecode的host https://smarthosts.googlecode.com/svn/trunk/hosts
- linux下删除修改时间为某天之前的文件
time_file #新建一个标识文件,修改时间为2014年4月9日0点0分 find . ! -cnewer time_file | xargs rm #删除最后修改时间在上述标识文件之前的所有文件
- linxu安装OSX
下载OS X Mavericks 10.9 Retail VMware Image安装vmware10.01打开unlock-all-v110,运行install.sh 打开vmx. 更新系统. 安装 ...
- [Java] 垃圾回收机制 ( Garbage Collection ) 简介
自动垃圾回收( Automatic Garbage Collection ) 自动垃圾回收,是指在堆(Heap)内存上分辨哪些对象还在被使用,哪些对象没有被使用,并清除没有被使用的对象.所以,这里的垃 ...
- python_Opencv_绘图
opencv中也可以用一些函数来绘图 直接上源码,例子: # -*- coding: utf-8 -*- import numpy as np import cv2 # 黑色的图片 img=np.ze ...