P1248 加工生产调度

题目描述

某工厂收到了n个产品的订单,这n个产品分别在A、B两个车间加工,并且必须先在A车间加工后才可以到B车间加工。

某个产品i在A、B两车间加工的时间分别为Ai、Bi。怎样安排这n个产品的加工顺序,才能使总的加工时间最短。这里所说的加工时间是指:从开始加工第一个产品到最后所有的产品都已在A、B两车间加工完毕的时间。

输入格式

第一行仅—个数据n(0<n<1000),表示产品的数量。

接下来n个数据是表示这n个产品在A车间加工各自所要的时间(都是整数)。

最后的n个数据是表示这n个产品在B车间加工各自所要的时间(都是整数)。

输出格式

第一行一个数据,表示最少的加工时间;

第二行是一种最小加工时间的加工顺序。

输入输出样例

输入 #1
5
3 5 8 7 10
6 2 1 4 9
输出 #1

34

1 5 4 2 3

思路

代码

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

const int N=1010;

int n;

struct no {
	int a,b,minn,pm;
} t1[N],t2[N];

bool cmp(no a,no b) {
	return a.minn<b.minn;
}

int main() {
	scanf("%d",&n);
	for(int i=1; i<=n; i++)
		scanf("%d",&t1[i].a);
	for(int i=1; i<=n; i++)
		scanf("%d",&t1[i].b);
	for(int i=1; i<=n; i++) {
		t1[i].minn=min(t1[i].a,t1[i].b);
		t1[i].pm=i;
	}
	sort(t1,t1+n+1,cmp);
	int l=1,r=n;
	for(int i=1; i<=n; i++) {
		if(t1[i].minn==t1[i].a)
			t2[l++]=t1[i];
		else
			t2[r--]=t1[i];
	}
	int i=1,at=0,bt=0,t=t2[1].a;
	t2[n+1].a=0;
	while(i<=n) {
		bt+=t2[i].b;
		at=t2[++i].a;
		if(at<bt) {
			bt-=at;
			t+=at;
			at=0;
		} else if(at>=bt) {
			t+=at;
			at=0;
			bt=0;
		}
	}
	t+=bt;
	printf("%d\n",t);
	for(int i=1; i<=n; i++)
		printf("%d ",t2[i].pm);
	printf("\n");
	return 0;
}

 

 

posted @ 2019-11-04 23:26  双子最可爱啦  阅读(173)  评论(0编辑  收藏  举报