加工生产调度

题目描述

某工厂收到了 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;
}
相关推荐
DeeplyMind6 分钟前
第七章:数据结构大比拼
数据结构·计算机科学·少儿编程·少儿科技读物
元亓亓亓7 分钟前
考研408--数据结构--day8--遍历序列&线索二叉树
数据结构·考研·408·线索二叉树
xiaoxue..13 分钟前
合并两个升序链表 与 合并k个升序链表
java·javascript·数据结构·链表·面试
啊森要自信32 分钟前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
仟濹1 小时前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事1 小时前
简单模板笔记
数据结构·笔记·算法
YuTaoShao1 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头1 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa1 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior1 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪