- 博客(6)
- 收藏
- 关注
原创 01背包问题动态规划代码
状态转移方程解释:value[x][y] = max{value[x - 1][y], value[x - 1][y - w[i]] + v[i]}value[x - 1][y - w[i]] + v[i]:放此物品前上一个状态的价值 + 此物品价值 = 当前重量下放此物品后的价值。value[x][y]:当前状态的最大价值,也就是要填到小方格里的数。补充:回溯根据最大价值推算背包中放置的物品是哪些(先鸽一会)value[x - 1][y]:当前重量下不放此物品的价值。
2024-02-01 19:21:40 187 1
原创 力扣每日一题240122
从分析方法中我们可以抽象出,让程序把给定串和模板串从高位到低位依次比较,如果相同,则说明第i位(当前位)不用换,继续看下一位;如果不相同,则说明给定串的第i位需要由高位换到低位,换上来的那个数字是模板串中的第i位。我们再去给定串中找到与模板串中第i位相同的数字,在给定串中进行交换。这是一个重要的概念。以此类推,如果给定的数据是4312,前两位都不需要动,交换第三位和第三大的数。先由任意一个例子开始思考,如2431.显而易见,最符合题意的交换方式是把4换到最高位,最高位的2换到4原来所在的那一位。
2024-01-22 21:32:47 384 1
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人