加工生产调度

题目描述

某工厂收到了 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;
}
相关推荐
郭涤生19 分钟前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿23 分钟前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz35 分钟前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能35 分钟前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****36 分钟前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能43 分钟前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 小时前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 小时前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法
汀、人工智能1 小时前
[特殊字符] 第76课:单词拆分
数据结构·算法·均值算法·前缀树·trie·单词拆分