1492 探案第二部

 时间限制: 1 s
 空间限制: 128000 KB
 
 
题目描述 Description

我们伟大的 Sherlock·Holmes 先生最近遇上了一件相当棘手的案子,随着对案情逐渐深入的研究,他开始意识到:此案地域横跨欧洲,而起因可以追溯到50年前!为了尽快搜集各方面的线索,他决定与Dr. Watson分头行动。

Holmes列出了若干需要的线索:某处的一些雪茄烟灰;地下室油画上的颜料的呈色;Black兄弟与他们邻里的联系……诸如此类。而搜集这些线索需要一定的时间。不过,有些线索是相关联的,即在得到某个线索的时候,一并可以得出其他结论(我们可以认为这是不需要时间的)

请充分相信Holmes先生!他无比敏锐的思维足够将所有线索串联,以完美的推理侦破这件名噪一时的大案!

输入描述 Input Description

第一行为N,表示N个需要搜集的线索(N<=1000)

接下来N行,每行两个整数ai,bi, 分别表示Holmes,Watson搜集第i个线索所需要的时间。(ai,bi<=15)

接下来若干行,每行两个整数x,y,表示得到x, 同时能够得到y。

输出描述 Output Description

一个整数,即搜集所有线索的最小耗时。

样例输入 Sample Input

2

5 6

3 9

1 2

样例输出 Sample Output

5

原图缩点,得到一条链

那么只需要探索链的起点即可

可以想到dp[i][j] 表示第1个人用时为i,第2个人用时为j时否可行

把第二维压去

dp[i] 表示 第1个人用时为i时,第2个人的最小用时

枚举第i个任务,枚举 当前第1个人用时为j

如果第1个人在j用时能做这个任务 那么

dp[j]=min(dp[j-timea[i]],dp[j]+timeb[i]) 即给第一个人做、第二个人做 取最优

如果第1个人在j用时不能做这个任务,那么只能给第2个人做

dp[j]+=timeb[i]

最后答案就是枚举所有的i,ans=min(max(i,dp[i]))

#include<cstdio>
#include<algorithm> #define N 1001 using namespace std; int n,a[N],b[N]; int front[N],nxt[N*N],to[N*N],tot,from[N*N]; int col[N],cnt;
int st[N],top;
int dfn[N],low[N],tim;
bool ins[N]; int in[N];
int na[N],nb[N]; int dp[]; void add(int u,int v)
{
to[++tot]=v; nxt[tot]=front[u]; front[u]=tot; from[tot]=u;
} void init()
{
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%d%d",&a[i],&b[i]);
int x,y;
while(scanf("%d%d",&x,&y)!=EOF) add(x,y);
} void tarjan(int u)
{
dfn[u]=low[u]=++tim;
ins[u]=true; st[++top]=u;
for(int i=front[u];i;i=nxt[i])
if(!dfn[to[i]]) tarjan(to[i]),low[u]=min(low[u],low[to[i]]);
else if(ins[to[i]]) low[u]=min(low[u],dfn[to[i]]);
if(low[u]==dfn[u])
{
col[u]=++cnt; ins[u]=false;
na[cnt]=a[u]; nb[cnt]=b[u];
while(st[top]!=u)
{
na[cnt]=min(na[cnt],a[st[top]]);
nb[cnt]=min(nb[cnt],b[st[top]]);
col[st[top]]=cnt;ins[st[top--]]=false;
}
top--;
}
} void solve()
{
for(int i=;i<=n;i++)
if(!dfn[i]) tarjan(i);
for(int i=;i<=tot;i++)
if(col[from[i]]!=col[to[i]]) in[col[to[i]]]++;
int m=;
for(int i=;i<=cnt;i++)
if(!in[i]) m+=na[i];
for(int i=;i<=cnt;i++)
if(!in[i])
for(int j=m;j>=;j--)
if(j-na[i]>=) dp[j]=min(dp[j-na[i]],dp[j]+nb[i]);
else dp[j]+=nb[i];
int ans=m;
for(int i=m;i>=;i--) ans=min(ans,max(i,dp[i]));
printf("%d",ans);
} int main()
{
init();
solve();
}

codevs 1492 探案第二部的更多相关文章

  1. bgp选路原则【第二部】

    面向逻辑谈bgp选路原则(第二部) 终于到了BGP终极解析的第二部曲--BGP选路原则.与题目相呼应,我不会直接介绍选路原则的规则,而是从时间逻辑和空间逻辑上将所有的选路原则分层分类.因为只有从这种角 ...

  2. Swift Swift语言Storyboard教程:第二部

    本文由CocoaChina翻译小组@TurtleFromMars翻译自raywenderlich,原文:Storyboards Tutorial in Swift: Part 2 更新记录:该Stor ...

  3. tornado学习篇(第二部)

    执行字符串表示的函数,并为该函数提供全局变量 本篇的内容从题目中就可以看出来,就是为之后剖析tornado模板做准备,     #!usr/bin/env python #coding:utf-8 n ...

  4. Linux运维笔记--第二部

    第2部-重要目录结构详解 1.回顾Linux目录结构知识 /dev/            设备目录 /etc/             系统配置及服务配置文件,启动命令的目录 /proc       ...

  5. codevs——1700 施工方案第二季

    1700 施工方案第二季 2012年市队选拔赛北京  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description c国边防 ...

  6. Swift语言Storyboard教程:第二部

    本文由CocoaChina翻译小组@TurtleFromMars翻译自raywenderlich,原文:Storyboards Tutorial in Swift: Part 2 更新记录:该Stor ...

  7. codevs 1700 施工方案第二季

    1700 施工方案第二季 2012年市队选拔赛北京  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description c国边防 ...

  8. Python ( 高级 第二部)

    目录 模块和包 面向对象 部分一: 面向对象程序开发 面向对象封装: 对象的相关操作 面向对象封装: 类的相关操作 实例化的对象/ 定义的类删除公有成员属性和公有成员方法 部分二: 单继承 多继承 菱 ...

  9. A框架 第二部 实例化接收到的get类,调用父类抽象方法,自动执行方法call_user_func_array()

    01父类抽象类 abstract.php <?phpabstract class controller_abstract{ protected $app; function __construc ...

随机推荐

  1. PSP Daily——团队项目Alpha发布

    视频展示:优酷视频链接.文案如下 PSP Daily软件NABCD分析: 1) N (Need 需求) PSP Daily 解决了用户(软件工程课上学生)记录例行报告.写每周PSP表格和统计的需求.潜 ...

  2. 软件工程-东北师大站-第四次作业PSP

    1.本周PSP 2.本周进度条 3.本周累计进度图 代码累计折线图 博文字数累计折线图 4.本周PSP饼状图

  3. Thunder--Beta发布--美工+文案

    作业:https://edu.cnblogs.com/campus/nenu/SWE2017FALL/homework/1366 内容: 美工:原有功能展示.新增功能展示 程序图标 欢迎页面 我的书架 ...

  4. our team

    今天向大家介绍一下我们的团队,首先我们的团队叫“吉祥三宝”当然我们的三宝不是亲子关系,我们是兄弟关系,对,就是这样 下面来介绍一下我们的团队成团吧: 李奇原: 性格开朗.积极乐观.有责任心,擅长团队协 ...

  5. Hadoop环境搭建01

    根据马士兵老师的Hadoop进行的配置 1.首先列下来需要用到的软件 VirtulBox虚拟机.Centos7系统镜像.xshell.xftp.jdk安装包.hadoop-2.7.0安装包 2.在Vi ...

  6. Ubuntu16.04安装json-c

    1. 安装依赖 sudo apt-get install git gcc clang libtool autoconf automake doxygen valgrind 一些版本要求,如果版本过低可 ...

  7. 自定义ClassLoader,用于加载用户JAR包

    最近在考虑C/S结构程序的软件自动升级的实现方式,比如QQ.飞信等都自动升级的功能. 自动升级模块虽然还没有编码完成,但是思路还是比较清晰的. 自动升级过程中,升级文件的JAR包是专门加载到程序中去的 ...

  8. 微信小程序组件 加减号弹出框

    <!-- 点击立即抢拼弹出框 --> <view class='add-rob' bindtap="setModalStatus" data-status=&qu ...

  9. asp.net 中使用 pagedlist 分页并具有查询功能的实现方法

    用pagedlist在项目中做分页已N次了,今天再次用实例来实现一个带查询功能的分页例子. 1.在view代码: @using PagedList.Mvc@model BGZS.Models.User ...

  10. AtCoder Grand Contest 019 A: Ice Tea Store

    tourist出的题诶!想想就很高明,老年选手可能做不太动.不过A题还是按照惯例放水的. AtCoder Grand Contest 019 A: Ice Tea Store 题意:买0.25L,0. ...