思路: 动态方程很容易想到dp[i][j]=max(dp[i][j],dp[i-w-1][j-k]-k*ap[i],dp[i-w-1][j+k]+k*bp[i]): dp[i][j]表示第i天拥有j个石头的最大价值. 其实每次求得都是最有策略,所有dp[i-w-1]表示的就是i-w-1以前的最优,故不同往前遍历. 那么主要需要优化的是: 对于买石头,容量为j时,维护从j-k到j的转移最大值.即从哪个容量转移过来能得到最大效益. 对于卖石头,容量为j时,维护从j+k到j的转移最大值.即从哪个容量转…