我编写的一个小应用程序允许用户将各种项目添加到两个数组中。一些逻辑根据每个数组的内容计算一个数字。
数组 x 中的任何项目都可以放入数组 y 中,然后再返回。永远不能移动属于数组 y 的项目(除非它们是从数组 x 中移动的)。
用户可以使用简单的 javascript ui 在两个列表中移动这些项目。为了让事情更简单,我最初制作了一个简单的脚本:
- 将项目从 a 移到 y。
- 使用这种“可能性”执行一些逻辑
- 如果结果比以前小,则将 x 留在 y 中。
- 如果不是,则 x 保留在 x 中。
- 移至 x 中的下一项并重复。
我知道这是无效的。我已经阅读并被告知使用按位数学来记住可能性或“排列”,但在这个阶段我正在努力解决这个特定问题。
如果有人能够解释(伪代码很好)实现以下目标的最佳方法是什么,我将不胜感激。
数组 x = [100,200,300,400,500] 数组 y = [50,150,350,900]
使用这两个数组,对于 x 中的每个值,将该值和 x 中所有其他值的每个组合推送到数组 y 中。对于每一个我都会执行一些逻辑(即测试结果并将这个“排列”存储在一个数组中(一个代表 x 和 y 的两个数组的对象)。我预见这对于大数组来说非常昂贵,可能会重复很多组合。我觉得我快到了,但在最后阶段迷路了。
抱歉冗长的解释,并提前致谢!