day 37 | ● 1049. 最后一块石头的重量 II ● 494. 目标和 ● 474.一和零

1049. 最后一块石头的重量 II

与前一道分割等和子集的思路差不多,都是01背包问题。因为是采用滚动数组的形式,所以必须要倒序遍历才可以。

dp[i]代表着在i的限制下最大的承重。所以另一半就是all - dp【all / 2】

go 复制代码
func lastStoneWeightII(stones []int) int {
    all := 0
    for i := 0; i < len(stones); i++{
        all += stones[i]
    }
    sum := all/ 2

    dp := make([]int, sum + 1)

    for i := 0; i < len(stones);i++{
        for j := sum; j>= stones[i];j--{
            dp[j] = int(math.Max(float64(dp[j]), float64(dp[j - stones[i]] + stones[i])))
        }
    }
    return all - 2 * dp[sum]
}

494. 目标和

注意点比较多:

1、这是求次数的,所以是dp【j】 += dp【j - nums【i】】

2、要注意什么时候是不可能完成的

3、dp初值要赋好,dp【0】 = 1(但是对于普通的01背包的dp数组初始化为0就可以。)



go 复制代码
func findTargetSumWays(nums []int, target int) int {
    sum := 0
    for i := 0; i < len(nums); i++{
        sum += nums[i]
    } 
    if int(math.Abs(float64(target))) > sum {return 0} // 此时没有方案
    if (sum + target) % 2 == 1 {return 0}// 此时没有方案
    pos := (sum + target) / 2
    dp := make([]int, pos + 1)
    dp[0] = 1
    for i := 0; i < len(nums); i++{
        for j := pos; j >= nums[i]; j--{
            dp[j] += dp[j - nums[i]]
        }
    }
    return dp[pos]
}

474.一和零

看似是一个多重背包的问题,但是实际上是一个01背包,只是限制条件增加了,变成了一个两个维度的背包。

go 复制代码
func findMaxForm(strs []string, m int, n int) int {
    dp := make([][]int, m + 1)
    for i := 0 ; i <= m; i++{
        dp[i] = make([]int, n + 1)
    }

    for i := 0; i < len(strs); i++{
        zero := 0
        one := 0
        for j := 0; j < len(strs[i]); j++{
            if strs[i][j] == '0'{
                zero++
            }else{
                one++
            }
        }

        for j := m; j >= zero; j--{
            for k := n; k >= one; k--{
                dp[j][k] = int(math.Max(float64(dp[j][k]) , float64(dp[j - zero][k - one] + 1)))
            }
        }
    }
    return dp[m][n]
}
相关推荐
吴秋霖3 分钟前
主流反爬虫、反作弊防护与风控对抗手段
爬虫·算法·反爬虫技术
java1234_小锋15 分钟前
Scikit-learn Python机器学习 - 分类算法 - K-近邻(KNN)算法
python·算法·机器学习
智者知已应修善业18 分钟前
【矩阵找最大小所在位置】2022-11-13
c语言·c++·经验分享·笔记·算法·矩阵
shan&cen22 分钟前
Day04 前缀和&差分 1109. 航班预订统计 、304. 二维区域和检索 - 矩阵不可变
java·数据结构·算法
手握风云-27 分钟前
回溯剪枝的 “减法艺术”:化解超时危机的 “救命稻草”(二)
算法·机器学习·剪枝
QiZhang | UESTC40 分钟前
JAVA算法练习题day11
java·开发语言·python·算法·hot100
屁股割了还要学44 分钟前
【数据结构入门】排序算法(4)归并排序
c语言·数据结构·学习·算法·排序算法
努力学习的小廉1 小时前
我爱学算法之—— 位运算(上)
c++·算法
ゞ 正在缓冲99%…1 小时前
leetcode35.搜索插入位置
java·算法·leetcode·二分查找
lifallen2 小时前
字节跳动Redis变种Abase:无主多写架构如何解决高可用难题
数据结构·redis·分布式·算法·缓存