加工生产调度

题目描述

某工厂收到了 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;
}
相关推荐
listhi52027 分钟前
基于改进SET的时频分析MATLAB实现
开发语言·算法·matlab
Keep_Trying_Go1 小时前
基于Zero-Shot的目标计数算法详解(Open-world Text-specified Object Counting)
人工智能·pytorch·python·算法·多模态·目标统计
xl.liu1 小时前
零售行业仓库商品数据标记
算法·零售
confiself1 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子1 小时前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
CoderYanger2 小时前
递归、搜索与回溯-记忆化搜索:38.最长递增子序列
java·算法·leetcode·1024程序员节
xlq223223 小时前
22.多态(下)
开发语言·c++·算法
CoderYanger3 小时前
C.滑动窗口-越短越合法/求最长/最大——2958. 最多 K 个重复元素的最长子数组
java·数据结构·算法·leetcode·哈希算法·1024程序员节
不会c嘎嘎4 小时前
【数据结构】AVL树详解:从原理到C++实现
数据结构·c++
却话巴山夜雨时i4 小时前
394. 字符串解码【中等】
java·数据结构·算法·leetcode