我一直在复习算法以供实践,目前我正在研究一种我非常喜欢的排列算法: int range = end -我知道我可以将它存储在散列或类似的东西中,但这不是一个最佳的解决方案--我更喜欢不需要额外存储的解决方案。有人能给我个建议吗?PS:我不想使用STL置换机制,我也不想在某个地方引用另一个“唯一置换算法”。我想了解用于防止复制的机制,以便在可能的情况下,我可以将其构建到学习中。
对于每一个置换,如果其重量超过了max_weight,则停止对该置换的计算,移到下一个置换。就像。1,0,0,0 --> 1 finished, move to next 到目前为止,1,0-1,0是不超过max_weight 4的最佳组合我的问题是
由于单元数可达10000,支路重量超过max_weight时,计算停止,无需先生成全部排列。algo i