51 nod 1205 流水线调度
第1行:1个数N,表示作业的数量。(2 <= N <= 50000)
第2 - N + 1行:每行两个数,中间用空格分隔,表示在M1和M2上加工所需的时间a[i], b[i]。(1 <= a[i], b[i] <= 10000)。
输出完成所有作业所需的最少时间。
4
3 7
2 1
1 1
4 2
14
(1) 把作业按工序加工时间分成两个子集,
第一个集合中在S1上做的时间比在S2上少,
其它的作业放到第二个集合.
先完成第一个集合里面的作业, 再完成第二个集合里的作业.
(2) 对于第一个集合, 其中的作业顺序是按在S1上的时间的不减排列;
对于第二个集合, 其中的作业顺序是按在S2上的时间的不增排列.
#include<cstdio>
#include<algorithm>
using namespace std;
int n,k1,k2,c1,c2,time;
struct node1
{
int s1,s2;
}a[];
struct node2
{
int s1,s2;
}b[];
bool cmp1(node1 p,node1 q)
{
return p.s1<q.s1;
}
bool cmp2(node2 p,node2 q)
{
return p.s2>q.s2;
}
int main()
{
scanf("%d",&n);
int x,y;
for(int i=;i<=n;i++)
{
scanf("%d%d",&x,&y);
if(x<y)
{
k1++;
a[k1].s1=x;a[k1].s2=y;
}
else
{
k2++;
b[k2].s1=x;b[k2].s2=y;
}
}
sort(a+,a+k1+,cmp1);
sort(b+,b+k2+,cmp2);
for(int i=;i<=k1;i++)
{
c1+=a[i].s1;
time=max(c1,time);
time+=a[i].s2; }
for(int i=;i<=k2;i++)
{
c1+=b[i].s1;
time=max(c1,time);
time+=b[i].s2; }
printf("%d",time);
}
//变量p错误,p+ 当前在m1所用时间与m2、m1已用时间的差,是错误的
//因为一个在m1上加工完后,会立刻移开,下一个接上,所以这一个在m1上的时间不影响下一个
#include<cstdio>
#include<algorithm>
using namespace std;
int n,k1,k2,c1,c2,time;
struct node1
{
int s1,s2;
}a[];
struct node2
{
int s1,s2;
}b[];
bool cmp1(node1 p,node1 q)
{
return p.s1<q.s1;
}
bool cmp2(node2 p,node2 q)
{
return p.s2>q.s2;
}
int main()
{
scanf("%d",&n);
int x,y;
for(int i=;i<=n;i++)
{
scanf("%d%d",&x,&y);
if(x<y)
{
k1++;
a[k1].s1=x;a[k1].s2=y;
}
else
{
k2++;
b[k2].s1=x;b[k2].s2=y;
}
}
sort(a+,a+k1+,cmp1);
sort(b+,b+k2+,cmp2);
for(int i=;i<=k1;i++)
{
int p=max(,a[i].s1-(c2-c1));
time+=p;
c1+=a[i].s1;
c2+=a[i].s2;
time+=a[i].s2;
printf("%d\n",time);
}
for(int i=;i<=k2;i++)
{
if(c1+b[i].s1<=c2)
{
c1+=b[i].s1;
c2+=b[i].s2;
time+=b[i].s2;
}
else
{
int p=c1+b[i].s1-c2;
time+=p;
c1+=b[i].s1;
c2+=b[i].s2;
time+=b[i].s2;
printf("%d\n",time);
}
}
printf("%d",time);
}
错误代码
51 nod 1205 流水线调度的更多相关文章
- 51nod 1205 流水线调度
1205 流水线调度 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 N个作业{1,2,…,n}要在由2台机器M1和M2组成的流水线上完成加工.每个 ...
- 51 nod 1439 互质对(Moblus容斥)
1439 互质对 题目来源: CodeForces 基准时间限制:2 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 有n个数字,a[1],a[2],…,a[n].有一个集合,刚开 ...
- 51 nod 1495 中国好区间
1495 中国好区间 基准时间限制:0.7 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 阿尔法在玩一个游戏,阿尔法给出了一个长度为n的序列,他认为,一段好的区间,它的长度是& ...
- 51 nod 1427 文明 (并查集 + 树的直径)
1427 文明 题目来源: CodeForces 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 安德鲁在玩一个叫“文明”的游戏.大妈正在帮助他. 这个游 ...
- 51 nod 1055 最长等差数列(dp)
1055 最长等差数列 基准时间限制:2 秒 空间限制:262144 KB 分值: 80 难度:5级算法题 N个不同的正整数,找出由这些数组成的最长的等差数列. 例如:1 3 5 6 8 9 ...
- 51 nod 1421 最大MOD值
1421 最大MOD值 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 有一个a数组,里面有n个整数.现在要从中找到两个数字(可以 ...
- 51 nod 1681 公共祖先 (主席树+dfs序)
1681 公共祖先 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 有一个庞大的家族,共n人.已知这n个人的祖辈关系正好形成树形结构(即父亲向儿子连边). 在另 ...
- 51 nod 1766 树上的最远点对(线段树+lca)
1766 树上的最远点对 基准时间限制:3 秒 空间限制:524288 KB 分值: 80 难度:5级算法题 n个点被n-1条边连接成了一颗树,给出a~b和c~d两个区间,表示点的标号请你求出两个 ...
- 51 nod 1405 树的距离之和
1405 树的距离之和 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 给定一棵无根树,假设它有n个节点,节点编号从1到n, 求任意两点之间的距离(最短路径)之 ...
随机推荐
- angularJS1笔记-(13)-自定义指令(controller和controllerAs实现通信)
index.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- vue 组件 子向父亲通信用自定义方法用事件监听
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>T ...
- 删除log日志中包含某个字符的行
sed -i '/{Str}/d' abc.txt 假如你的log日志中某行有sleep字符,直接输入命令: sed -i '/sleep/d' log.log 如果删除的是一个变量的值,假如是var ...
- Flyway的第一次认识
1. 引言 想到要管理数据库的版本,是在实际产品中遇到问题后想到的一种解决方案,当时各个环境的数据库乱作一团,没有任何一个人(开发.测试.维护人员)能够讲清楚当前环境下的数据库是哪个版本,与哪个版本 ...
- Nginx4大模块——proxy、headers、upstream、stream
一:ngx_http_proxy_module 反向代理( reverse proxy) 方式是指用代理服务器来接受 Internet 上的连接请求, 然后将请求转发给内部网络中的上游服务器, 并将从 ...
- P4291 [HAOI2008]排名系统
题目描述 排名系统通常要应付三种请求:上传一条新的得分记录.查询某个玩家的当前排名以及返回某个区段内的排名记录.当某个玩家上传自己最新的得分记录时,他原有的得分记录会被删除.为了减轻服务器负担,在返回 ...
- python模拟浏览器爬取数据
爬虫新手大坑:爬取数据的时候一定要设置header伪装成浏览器!!!! 在爬取某财经网站数据时由于没有设置Header信息,直接被封掉了ip 后来设置了Accept.Connection.User-A ...
- maven 手动执行下载
先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令: mvn clean compile
- 【算法】Tarjan大锦集
Task1 Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面,查出谁是杀手. 警察能够对每一个人进行查证,假如查证的对象是平民,他会告诉警察,他认识 ...
- 使用JS在textarea在光标处插入内容
// 在光标处插入字符串 // myField 文本框对象 // myValue 要插入的值 function insertAtCursor(myField, myValue) { //IE supp ...