poj3249
显然是一道最短路径的题目,但是
1 ≤ n ≤ 100000, 0 ≤ m ≤ 1000000能轻松打爆dij+heap
怎么办?
挖掘题意,这是一个DAG图(有向无环图)
所以对于此类问题,我们有特殊的作法
对于DAG,拓扑序列在前的点的最短路一定会被先更新(值得思考)
所以我们只用对DAG做一次拓扑,然后依次更新最短路即可;(其实很像dp)
多个入度为0的点不影响结果;
再回到这题,由于给出的是点的权值
可以考虑拆点,将点i拆成点i1,i2,i1,i2之间连一条指向i2的有向边,权值为原先点的权值
原先所有入边连向i1,出边连i2,权值都是0,这样就搞定了
拆点的做法在后面的网络流中会经常用到(当然这题也可以不拆)
type link=^node;
node=record
po,len:longint;
next:link;
end; var w:array[..] of link;
v:array[..] of boolean;
c,r,q,d:array[..] of longint;
n,m,ans,i,t,f,s,x,y:longint;
p,g:link;
function max(a,b:longint):longint;
begin
if a>b then exit(a) else exit(b);
end; procedure add(x,y,z:longint); //邻接表
var p:link;
begin
new(p);
p^.po:=y;
p^.len:=z;
p^.next:=w[x];
w[x]:=p;
end; begin
while not eoln do
begin
readln(n,m);
for i:= to *n do
w[i]:=nil;
fillchar(r,sizeof(r),);
fillchar(c,sizeof(c),);
for i:= to n do //拆点
begin
readln(x);
add(i+n,i,x);
inc(r[i]);
inc(c[i+n]);
end;
for i:= to m do //建边
begin
readln(x,y);
add(x,y+n,);
inc(r[y+n]);
inc(c[x]);
end;
s:=;
fillchar(v,sizeof(v),false);
fillchar(q,sizeof(q),);
for i:= to *n do //先找入度为0的点
if r[i]= then
begin
inc(s);
v[i]:=true;
q[s]:=i;
end;
f:=;
while s<*n do //生成拓扑序列
begin
inc(f);
p:=w[q[f]];
while p<>nil do
begin
dec(r[p^.po]);
if r[p^.po]= then
begin
inc(s);
q[s]:=p^.po;
end;
p:=p^.next;
end;
end;
for i:= to *n do //d[i]表示从某个入度为0的点到达当前点的最大距离
if v[i] then d[i]:= else d[i]:=-;
ans:=-;
for i:= to *n do
begin
f:=q[i];
p:=w[f];
g:=nil;
while p<>nil do //按照拓扑序列依次更新所有到达的点
begin
t:=p^.po;
d[p^.po]:=max(d[p^.po],d[f]+p^.len);
g:=p;
p:=p^.next;
dispose(g); //注意这题多测加上巨大的n,m很有可能把链表挤爆,所以及时释放掉空间
end;
end;
for i:= to *n do
if c[i]= then ans:=max(d[i],ans);
writeln(ans);
end;
end.
拓扑序列复杂度O(m),最短路O(m)
所以总的复杂度O(m)
poj3249的更多相关文章
- POJ3249:Test for Job
传送门 很简单的一道题,被卡了几次,死于答案非法统计. 题意是求图里的一条最长的路径满足起点的入度和终点的出度都是0,而且图是DAG. 既然是DAG求最长路,DP即可.搞出拓扑序,逆序DP,然后统计所 ...
- poj3249 Test for Job ——拓扑+DP
link:http://poj.org/problem?id=3249 在拓扑排序的过程中进行状态转移,dp[i]表示从起点到 i 这个点所得到的的最大值.比如从u点到v点,dp[v]=max(dp[ ...
- poj3249 拓扑排序+DP
题意:给出一个有向无环图,每个顶点都有一个权值.求一条从入度为0的顶点到出度为0的顶点的一条路径,路径上所有顶点权值和最大. 思路:因为是无环图,则对于每个点经过的路径求其最大权值有,dp[i]=ma ...
- POJ3249(DAG上的dfs)
Test for Job Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 10567 Accepted: 2482 Des ...
- poj3249【拓扑排序】
//题意: 给出一个有向无环图,每个顶点都有一个权值. // 求一条从入度为0的顶点到出度为0的顶点的一条路径, // 路径上所有顶点权值和最大. //我觉得只要明 ...
- POJ3249 Test for Job(拓扑排序+dp)
Test for Job Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 10137 Accepted: 2348 Des ...
- poj3249 Test for job 【图的DAG dp】
#include <cstdio> #include <cstdlib> #include <iostream> #include <algorithm> ...
- poj3249 拓扑找最长路
Test for Job Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 11230 Accepted: 2651 Des ...
- Test for Job(poj3249)
Test for Job Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 10209 Accepted: 2372 Des ...
随机推荐
- NoSQL专家王涛访谈:为什么我们还要做一个NoSQL?
ChinaUnix:各位网友大家好,今天有幸请到王涛先生到CU做客,与大家交流一些工作经验.首先请王涛先介绍一下自己. 王涛:大家好,我是王涛.过去八年里我一直在IBM多伦多实验室从事DB2引擎研发的 ...
- 在Linux上部署和操作Couchbase
couchbase属于nosql系列,个人感觉它要比mongodb操作简单,mongo的查询语句太复杂.在数据的持久性方面它区别于其他nosql 的唯一大亮点是不受限于其内存分配了多少,只要磁盘空间够 ...
- 源码编译安装LAMP环境及配置基于域名访问的多虚拟主机
实验环境及软件版本: CentOS版本: 6.6(2.6.32.-504.el6.x86_64) apache版本: apache2.2.27 mysql版本: Mysql-5.6.23 php版本 ...
- Hello World 的makefile模板及其分析
makefile模板: ifeq ($(KERNELRELEASE),) //判断KERNELRELEASE是否为空,只有执行make的当前目录为内核源代码目录时,该变量才不为空. KERNELDIR ...
- Python-Day1 Python基础学习
一.Python3.5.X安装 1.Windows Windows上找度娘搜索“Python for windows下载”就OK了,安装的时候可以勾选设置环境变量,也可以安装完手动设置,这样在cmd中 ...
- uva401 - Palindromes结题报告
题目地址 : http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- MYSQL外键约束的参照操作
如果表A的主关键字是表B中的字段,则该字段称为表B的外键,表A称为主表,表B称为从表.外键是用来实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常 ...
- 在cmd命令行下登录本地oracle数据库与服务器上的oracle
一.本地登录 cmd->sqlplus 用户名/密码@数据库名 (as sysdba)->enter注:如果此用户名不是系统用户sys,scott,system就不需要加as sysdba ...
- Webx框架自带的petstore
Webx框架:http://openwebx.org/ petstore:webx3/webx-sample/petstore/tags/3.0/petstore 编译之后:mvn jetty:run ...
- Code for the Homework2
第二次作业,最近有点忙,一直没写,先发一下,关节角计算有点问题,后面抽时间改 #include<iostream> #include <Eigen/Dense> #includ ...