加工生产调度

题目描述

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

某个产品 在 A,B 两车间加工的时间分别为 。怎样安排这 n 个产品的加工顺序,才能使总的加工时间最短。

这里所说的加工时间是指:从开始加工第一个产品到最后所有的产品都已在 A,B 两车间加工完毕的时间。

输入格式

第一行仅---个数据 ,表示产品的数量;

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

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

输出格式

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

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

样例

样例输入

复制代码
复制5
3 5 8 7 10
6 2 1 4 9

样例输出

复制代码
复制34
1 5 4 2 3

写作不易,点个赞呗!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!


cpp 复制代码
#include <bits/stdc++.h>
#include <string.h>
using namespace std;
struct node{
	int a;
	int b;
	int c;
}a[100005];
int v[100005];
inline bool cmp(node x,node y){
	return min(x.a,y.b)<min(x.b,y.a);
}
int main(){
	int n,ans=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i].a;
		ans+=a[i].a;
		a[i].c=i;
	}
	for(int i=1;i<=n;i++){
		cin>>a[i].b;
	}
	int ta=0,tb=0;
	sort(a+1,a+1+n,cmp);
	for(int i=1;i<=n;++i){
		ta+=a[i].a;
		tb=max(ta,tb)+a[i].b;
		v[i]=a[i].c;
}
    cout<<tb<<endl;
    for(int i=1;i<=n;++i){
    	cout<<v[i]<<" ";
	}
	return 0;
}
相关推荐
2501_924889555 小时前
商超高峰客流统计误差↓75%!陌讯多模态融合算法在智慧零售的实战解析
大数据·人工智能·算法·计算机视觉·零售
jingfeng5145 小时前
C++模板进阶
java·c++·算法
地平线开发者6 小时前
征程 6X | 常用工具介绍
算法·自动驾驶
地平线开发者6 小时前
理想汽车智驾方案介绍 2|MindVLA 方案详解
算法·自动驾驶
艾莉丝努力练剑6 小时前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法
地平线开发者7 小时前
LLM 中评价指标与训练概要介绍
算法·自动驾驶
Ghost-Face7 小时前
关于并查集
算法
zhangfeng11337 小时前
以下是基于图论的归一化切割(Normalized Cut)图像分割工具的完整实现,结合Tkinter界面设计及Python代码示
开发语言·python·图论
flashlight_hi8 小时前
LeetCode 分类刷题:2529. 正整数和负整数的最大计数
python·算法·leetcode
花火|8 小时前
算法训练营day60 图论⑩ Bellman_ford 队列优化算法、判断负权回路、单源有限最短路
算法·图论