这个情景用什么思路解决比较好?请教各位解决思路

2019-07-08 09:49:31 +08:00
 xiaojunjor

有两个数组

数组 A 是一个二维数组,如 [[10, 18],[23, 3, 9],[8, 16, 24, 31]]
数组 B 是一个对象数组,如 [{value:10, elecount:2},{value:24, elecount:3}]

需要数组 B 的每个对象(比如元素{value:10, elecount:2})从数组 A 中选择不少于 elecount 个数(该对象即为 2 个)的一维数组,再从这些数组中每个数组取出一个数,相加的和不小于且最接近该对象的 value (该对象即为 10 )

比如{value:10, elecount:2},需要从数组 A 中选择不少于 2 个的一维数组,从这 2 个或多于 2 个的一维数组中每个数组取出一个数,相加的值不小于且最接近 10

1.数组 A 中每个数组的元素可以有剩余(即最后没有参与运算的)

2.数组 A 中的每个一维数组中的每个元素只能参与运算一次

该例子的结果为	
[
  {value:10, elecount:2, eles:[3, 8]},
  {value:24, elecount:3, eles:[10, 9, 16]},
]

3.结果可能不唯一

如 A 数组为[[10, 18],[23, 3, 3],[8, 16, 24, 31]] 
B 数组为[{value:10, elecount:2},{value:24, elecount:3}]
则结果不唯一,A 中的数组[23, 3, 3]中的元素 3 取随机一个即可

4.如果 B 中存在 elecount 大于 A 中一维数组的个数,或 value 大于 A 中数组元素相加的最大值,则视为 B 中该元素无结果

如 A 数组为[[10, 18], [23, 3, 9], [8, 16, 24, 31]]
B 数组为[{value:10, elecount:2}, {value:90, elecount:3}, {value:32, elecount:5}]
则 B 数组第二个元素和第三个元素无结果
1096 次点击
所在节点    程序员
1 条回复
guyeu
2019-07-08 10:15:01 +08:00
动态规划

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/580884

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX