让我们来建造一艘新的海盗船。船上有 N个旗杆,每根旗杆被分成单位长度的小节。旗杆的长度等于它被分成的小节的数目。每根旗杆上会挂一些帆,每张帆正好占据旗杆上的一个小节。在一根旗杆上的帆可以任意排布在不同的小节中,但是每个小节上至多能挂一张帆。
在风中,帆的不同排布方式会产生不同的推动力。靠近船头的帆比它后面的相同高度上的帆获得的推动力少,换句话说,靠近船头的帆的推动力由于受它后面相同高度的帆的影响而打了折扣。对于任意一张帆,它的推动力折扣等于在它后面并且和它在同一高度的帆的数目。
所有帆的任意一种位置组合的推动力折扣总和等于在该位置下所有帆的推动力折扣的总和。
前 后
这条船上有6个旗杆,从前(图上的左边)到后的高度分别是3,5,4,2,4和3。图中所示的帆的位置组合的总推动力折扣是10。上图给出了每张帆自己的推动力折扣。
任务
给定N个旗杆的高度和每个旗杆上挂的帆的数目,写一个程序求出所有位置组合中的可能达到的最小的总推动力折扣。