狐猬编程:货运

玩具厂生产了一批玩具需要运往美国销售。该批玩具根据大小,已经将其打包装在不同的包装盒里用以运输。该批玩具包装盒共有六个型号,分别1*1*h、2*2*h、3*3*h、4*4*h、5*5*h、6*6*h的包装盒。由于疫情的影响,运输价格十分昂贵,海运公司只提供给玩具厂6*6*h型号的集装箱。公司聘请你为其设计最优方案,求出最优方案下需要多少集装箱运送该批货物。

输入格式

第一行一个正整数t(1≤t≤100),t表示数据组数;

每组数据一行,一行中有空格隔开的6个正整数,依次表示1*1*h、2*2*h、3*3*h、4*4*h、5*5*h、6*6*h玩具包装盒各自的数量,每个包装盒不超过10000。

输出格式

对于每组数据,仅输出一个整数,表示最少需要多少集装箱。

输入/输出例子1

输入:

3

0 0 4 0 0 1

10 10 10 10 10 10

10000 10000 10000 10000 10000 10000

输出:

2

33

32500

样例解释

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int d[10];
int c[]={0,5,3,1};
int cone[]={0,7,6,5};
int main()
{
	int t,ans;
	cin>>t;
	while(t--){
		ans=0;
		for(int i=1;i<=6;i++)
			cin>>d[i];
		ans+=d[6]+d[5]+d[4]+(d[3]+3)/4;
		d[1]-=d[5]*11;
		d[2]-=d[4]*5;//   (6*6-4*4)/(2*2)
		d[2]-=c[d[3]%4];//	 3*3剩余的空间优先填2*2 
		d[1]-=cone[d[3]%4];// 3*3填完2*2后再填1*1 
		if(d[2]<=0)
		{
			d[1]+=d[2]*4;// 如果d[2]小于0,则小于0的部分用1*1替换 
			if(d[1]>0) ans+=(d[1]+35)/36;
		}
		else{
			ans+=(d[2]+8)/9;
			if(d[2]%9) //一定得注意只有当d[2]有剩余的前提下才有得减 
				d[1]-=(9-d[2]%9)*4;//放2*2的箱子剩余的空间填充1*1 
			if(d[1]>0) ans+=(d[1]+35)/36;
		}
		cout<<ans<<endl;
	}
	return 0;
}
相关推荐
鱼鱼块11 小时前
《最小栈的巧妙设计:用辅助栈实现 O(1) 获取最小值》
javascript·算法·面试
San3011 小时前
反转字符串与两数之和:两道简单题背后的 JavaScript 思维深度
javascript·算法·面试
喜欢吃燃面11 小时前
算法竞赛中的堆
c++·学习·算法
资深web全栈开发11 小时前
LeetCode 1590:使数组和能被 p 整除(前缀和 + 哈希表优化)
算法·leetcode·前缀和·算法优化·哈希表·go 语言·取模运算
CoderYanger11 小时前
递归、搜索与回溯-综合练习:27.黄金矿工
java·算法·leetcode·深度优先·1024程序员节
zs宝来了11 小时前
HOT100系列-堆类型题
数据结构·算法·排序算法
Christo311 小时前
ICML-2019《Optimal Transport for structured data with application on graphs》
人工智能·算法·机器学习·数据挖掘
sin_hielo11 小时前
leetcode 1590
数据结构·算法·leetcode
吃着火锅x唱着歌11 小时前
LeetCode 2748.美丽下标对的数目
数据结构·算法·leetcode
做怪小疯子11 小时前
LeetCode 热题 100——二叉树——二叉树的中序遍历
算法·leetcode·职场和发展