日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode 474. Ones and Zeroes | 474. 一和零(双约束背包问题)

發(fā)布時間:2024/2/28 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode 474. Ones and Zeroes | 474. 一和零(双约束背包问题) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題目

https://leetcode.com/problems/ones-and-zeroes/

題解

這是一個雙約束的背包問題。此題需要的前置知識,可以參考我之前的博客:算法設計與分析 0-1背包問題 動態(tài)規(guī)劃解法【超詳細】

針對本題,思路如下:

在實現(xiàn)上,為了避免 i-1 的越界判斷,將整個數(shù)組的 i=0 位置空出來,顯得更整潔一些。

class Solution {public int findMaxForm(String[] strs, int m, int n) {int L = strs.length;int[][] weight = new int[L + 1][2];for (int i = 0; i < L; i++) {int z = 0;int o = 0;for (int j = 0; j < strs[i].length(); j++) {if (strs[i].charAt(j) == '0') {z++;} else {o++;}}weight[i + 1][0] = z;weight[i + 1][1] = o;}int[][][] dp = new int[L + 1][m + 1][n + 1];for (int i = 1; i <= L; i++) { // 第i個物品(序號從1開始)for (int mFree = 0; mFree <= m; mFree++) { // 背包剩余x容量for (int nFree = 0; nFree <= n; nFree++) { // 背包剩余y容量if (weight[i][0] > mFree || weight[i][1] > nFree) {dp[i][mFree][nFree] = dp[i - 1][mFree][nFree];} else {dp[i][mFree][nFree] = Math.max(dp[i - 1][mFree - weight[i][0]][nFree - weight[i][1]] + 1, dp[i - 1][mFree][nFree]);}}}}return dp[L][m][n];} }

總結

以上是生活随笔為你收集整理的leetcode 474. Ones and Zeroes | 474. 一和零(双约束背包问题)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。