题目链接

题目描述

用2 台处理机A 和B 处理n 个作业。设第i 个作业交给机器A 处理时需要时间i a ,若由机器B 来处理,则需要时间i b 。由于各作业的特点和机器的性能关系,很可能对于某些i,有ai >=bi,而对于某些j,j≠i,有aj < bj 。既不能将一个作业分开由2 台机器处理,也没有一台机器能同时处理2 个作业。设计一个动态规划算法,使得这2 台机器处理完这n个作业的时间最短(从任何一台机器开工到最后一台机器停工的总时间)。研究一个实例: (a1,a2,a3,a4,a5,a6)=(2,5,7,10,5,2);(b1,b2,b3,b4,b5,b6)=(3,8,4,11,3,4)。 对于给定的2 台处理机A 和B处理n 个作业,找出一个最优调度方案,使2台机器处理完这n 个作业的时间最短。

输入

的第1行是1个正整数n<=200, 表示要处理n个作业。 接下来的2行中,每行有n 个正整数,分别表示处理机A 和B 处理第i 个作业需要的处理时间。

输出

最短处理时间

样例输入

复制
6
2 5 7 10 5 2
3 8 4 11 3 4

样例输出

15

题解:
这道题是说有N个作业可以在两个机器A,B上操作,同一个作业在A,B上不能同时进行,并且在A,B上的操作时间不同,所以我们要考虑从1~n个作业,哪些在A上,哪些在B上操作,所需要的时间最短。
用动态规划的思想,我们做这样的思考:当操作第i个作业时,我们选A还是B机器?在题目的要求下,我们就需要根据i-1的操作和i操作之间的关联来解题了。 先定义变量:a[i]-操作i在机器A上的时间
b[i]-操作i在机器B上的时间
f[i][j]操作到第i个作业时,在A机器已经花费j时间的情况下,找到b机器操作的时间 这道题可以这样来做:当我们全部选A操作的时候,时间上限为a[i]的和,即suma,所以作业从1~n在A上操作的时间都不会超过suma。
我们就可以在A机器操作时间0<=j<=suma的范围内,操做到第i个操作时,在B机器上所花的最短时间。
最短时间:1.当a[i] >j时,f[i][j]=f[i-1][j]+b[i];即在操作到i作业时,A机器所花费的时间大于j,所以不能再A机器上操作了,所以这时应该选择B机器,就要找在操作到i-1作业时,
A机器已经花费j时间的情况下,B机器已经操作的时间f[i-1][j],然后在i操作时选了B,就是f[i-1][j]+b[i]了。
2.当a[i]<=j时,f[i][j]=min(f[i-1][j-a[i]],f[i-1][j]+b[i]);,可能选A机器,可能选B机器,如果选A机器,接要找在操作到i-1作业,A已经花费的时间为j-a[i]时B机器的时间f[i-1][j-a[i]],因为没选B,所以这时候f[i][j]的时间与f[i-1][j-a[i]]相等。
当操作到第n个操作时,从A机器操作时间0~suma的情况下,各个B机器操作的最短时间就找出来了。我们要在A机器花费时间0~suma的时间段里,逐一比较A,B机器的时间,会按最长的时间选出A,B机器的代表,
再在这suma个时间代表中选出最小的哪一个作为最短花时间。
代码如下:
#include<bits/stdc++.h>
using namespace std;
#define MAX 201
int a[MAX];//a[i],A机器 处理i作业花费时间
int b[MAX];//b[i],B机器 处理i作业花费时间
int f[MAX][];// f[i][j],在处理i作业时A机器花费j时间的情况下B机器花费的最小时间
int suma=;//如果所有作业全部由A机器处理,最大时间限制
int min(int x,int y)
{
return x<y?x:y;
}
int max(int x,int y)
{
return x>y?x:y;
}
int dealWith(int n)
{ for(int i=;i<=n;i++)
{
for(int j=;j<=suma;j++)
{
if(a[i]<=j)
{
f[i][j]=min(f[i-][j-a[i]],f[i-][j]+b[i]);
}
else
{
f[i][j]=f[i-][j]+b[i];
} } }
int m=;
for(int j=;j<=suma;j++)
{
int t;
t=max(j,f[n][j]);
m=min(m,t); } return m;
}
int main()
{
int n;
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
suma+=a[i];
}
for(int i=;i<=n;i++)
{
scanf("%d",&b[i]);
}
int m=dealWith(n);
printf("%d\n",m);
return ;
}
 

动态规划——独立任务最优调度(Independent Task Scheduling)的更多相关文章

  1. suseoj 1209: 独立任务最优调度问题(动态规划)

    1209: 独立任务最优调度问题 时间限制: 1 Sec  内存限制: 128 MB提交: 3  解决: 2[提交][状态][讨论版][命题人:liyuansong] 题目描述 用2台处理机A和B处理 ...

  2. LTE:上行调度请求(Scheduling Request,SR) LTE:下行资源分配类型

    http://blog.sina.com.cn/s/blog_927cff010101a7yh.html 上行调度请求(Scheduling Request,SR) 如果UE没有上行数据要传输,eNo ...

  3. 实现运行在独立线程池的调度功能,基于Spring和Annotation

    使用Spring的注解(@Scheduled)声明多个调度的时候,由于其默认实现机制,将导致多个调度方法之间相互干扰(简单理解就是调度不按配置的时间点执行). 为了解决该问题尝试了修改线程池大小,但是 ...

  4. Task Scheduling

    Introduction In the past, developers have generated a Cron entry for each task they need to schedule ...

  5. LeetCode.1029-两城调度(Two City Scheduling)

    这是小川的第383次更新,第412篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第245题(顺位题号是1029).公司计划采访的人数为2N.将第i个人飞往城市A的费用是[ ...

  6. [Swift]LeetCode1029. 两地调度 | Two City Scheduling

    There are 2N people a company is planning to interview. The cost of flying the i-th person to city A ...

  7. RR调度(Round-robin scheduling)简单介绍

    在RR调度策略下,一个线程会一直运行.直到: 自愿放弃控制权 被更高优先级的线程抢占 时间片用完 例如以下图所看到的,A在用完自己的时间片后,将CPU运行权让给线程B.于是A离开Read队列,而B进入 ...

  8. 题解 AT4170 【[ABC103A] Task Scheduling Problem】

    翻译 有 \(3\) 个正整数 \(a\).\(b\).\(c\),请你输出这 \(3\) 个数中的最大值 \(-\) 最小值的差. 分析 求最大值 \(-\) 最小值的差,我们自然可以使用 for ...

  9. SQL Server 2012中Task是如何调度的?

    SQL Server 2012中Task是如何调度的?[原文来自:How It Works: SQL Server 2012 Database Engine Task Scheduling]     ...

随机推荐

  1. CentOS 7 x64下Apache+MySQL(Mariadb)+PHP5.6的安装

    每次搭建新服务器,都要来来回回把这些包再装一下,来来回回搞了不下20遍了吧,原来都是凭经验,配置过程中重复入坑是难免的,故写此文做个备忘.虽然有像xampp这样的集成包,但是在生产环境的Linux发行 ...

  2. UOJ #277 BZOJ 4739 定向越野 (计算几何、最短路)

    手动博客搬家: 本文发表于20181208 14:39:01, 原地址https://blog.csdn.net/suncongbo/article/details/84891710 哇它居然显示出图 ...

  3. 【ACM】hdu_1234_开门人和关门人_201307300845

    开门人和关门人Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  4. 洛谷 P3252 [JLOI2012]树

    P3252 [JLOI2012]树 题目描述 在这个问题中,给定一个值S和一棵树.在树的每个节点有一个正整数,问有多少条路径的节点总和达到S.路径中节点的深度必须是升序的.假设节点1是根节点,根的深度 ...

  5. Linux查看文件内容命令:less(转)

    less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件. 语法 less [参数] 文件 参数说明: -b <缓冲 ...

  6. 【CSS】隐藏多行文本框Textarea在IE中的垂直滚动栏

    在<[CSS]禁止Google浏览器同意定义调整多行文本框>(点击打开链接)中已经提及过怎样使多行文本框Textarea在一些DOM2的浏览器中固定下来. 这不,多行文本框Textarea ...

  7. maven 镜像使用

    maven中的snapshot来源与注意事项 maven中的snapshot来源与注意事项 (2012-04-23 15:37:48) 转载▼ 标签: 杂谈 分类: java maven的依赖管理是基 ...

  8. C++求解汉字字符串的最长公共子序列 动态规划

        近期,我在网上看了一些动态规划求字符串最长公共子序列的代码.可是无一例外都是处理英文字符串,当处理汉字字符串时.常常会出现乱码或者不对的情况. 我对代码进行了改动.使用wchar_t类型存储字 ...

  9. c14---排序,查找

    // // main.c // 冒泡排序 // // Created by xiaomage on 15/6/10. // Copyright (c) 2015年 xiaomage. All righ ...

  10. HP Z240组建磁盘阵列RAID1