一、题目描述
一个业务芯片的容量为10G,可支持两种不同的业务类型A、B。芯片的约束如下:
1.A业务容量为2.5G,一个芯片上最多可配置4路业务;
2.B业务容量为10G,一个芯片上最多可配置1路业务;
3.由于业务容量限制,配置了A业务后,该芯片就不能配置B业务;
4.不能跨芯片占用资源,即业务只能配置在一块芯片上,不能占用一块芯片的容量,再占用另外芯片容量;
5.为了保证使用最少的芯片资源,业务配置时,按芯片编号从小到大顺序依次配置,并优先使用已经占用的芯片。
由于业务容量最小为2.5G,以最小业务容量为单位,一个芯片可以划分为4个资源区,将资源区依次编号为1,2,3,4。
一块板卡上有M块芯片,用户进行一系列业务配置后,请输出最后一个业务对应的芯片编号和芯片资源D,如果没有可用资源返回0 0
二、输入描述
板卡芯片数量M,芯片范围为1-32
用户业务配置数量N,数量为1-128
用户业务配置,业务配置间以空格分割
三、输出描述
芯片编号 资源区编号
四、测试用例
1、输入
3
4
B A B A
2、输出
2
2
3、说明
B分配到芯片1,资源1
A分配到芯片2,资源1
B分配到芯片3,资源1<
本文介绍了华为OD机试中关于芯片资源限制的Java编程题目,涉及芯片容量、业务配置规则以及如何保证使用最少芯片资源。通过具体输入输出示例,解释了业务配置过程,并提供了算法源码。
订阅专栏 解锁全文
798

被折叠的 条评论
为什么被折叠?



